tags:

views:

6710

answers:

5

Can you simply delete the directory from your python installation, or are there any lingering files that you must delete?

+7  A: 

It varies based on the options that you pass to install and the contents of the distutils configuration files on the system/in the package. I don't believe that any files are modified outside of directories specified in these ways.

Notably, distutils does not have an uninstall command at this time.

It's also noteworthy that deleting a package/egg can cause dependency issues -- utilities like easy_install attempt to alleviate such problems.

cdleary
Can you please update this to directly address the lingering files part of the question?
S.Lott
I thought I did -- no files are created outside of the directories specified by the distutils configuration and install flags, so any "lingering" files will exist in these directories. It varies from package to package.
cdleary
@cdleary: thanks, but, I was hoping you'd simply clarify and strengthen your answer, not add a long comment thread.
S.Lott
@S.Lott: Sorry, but I don't know which part of the answer you want clarification on -- can you be more specific?
cdleary
+1  A: 

If this is for testing and/or development purposes, setuptools has a develop command that updates every time you make a change (so you don't have to uninstall and reinstall every time you make a change). And you can uninstall the package using this command as well.

If you do use this, anything that you declare as a script will be left behind as a lingering file.

Jason Baker
+1  A: 

The three things that get installed that you will need to delete are:

  1. Packages/modules
  2. Scripts
  3. Data files

Now on my linux system these live in:

  1. /usr/lib/python2.5/site-packages
  2. /usr/bin
  3. /usr/share

But on a windows system they are more likely to be entirely within the Python distribution directory. I have no idea about OSX except it is more likey to follow the linux pattern.

Ali A
+1  A: 

Yes, it is safe to simply delete anything that distutils installed. That goes for installed folders or .egg files. Naturally anything that depends on that code will no longer work.

If you want to make it work again, simply re-install.

By the way, if you are using distutils also consider using the multi-version feature. It allows you to have multiple versions of any single package installed. That means you do not need to delete an old version of a package if you simply want to install a newer version.

Salim Fadhley
+1  A: 

I just uninstalled a python package, and even though I'm not certain I did so perfectly, I'm reasonably confident.

I started by getting a list of all python-related files, ordered by date, on the assumption that all of the files in my package will have more or less the same timestamp, and no other files will.

Luckily, I've got python installed under /opt/Python-2.6.1; if I had been using the Python that comes with my Linux distro, I'd have had to scour all of /usr, which would have taken a long time.

Then I just examined that list, and noted with relief that all the stuff that I wanted to nuke consisted of one directory, /opt/Python-2.6.1/lib/python2.6/site-packages/module-name/, and one file, /opt/Python-2.6.1/lib/python2.6/site-packages/module-x.x.x_blah-py2.6.egg-info.

So I just deleted those.

Here's how I got the date-sorted list of files:

find "$@" -printf '%T@ ' -ls | sort -n | cut -d\ -f 2-

(I think that's got to be GNU "find", by the way; the flavor you get on OS X doesn't know about "-printf '%T@'")

I use that all the time.

offby1