i'm working on a big python project, and i'm really sick if .pyc and *~ files. I'd like to remove them. I've seen that the -X
flag of git clean would remove untracked files. As you can imagine, i'm not tracking .pyc
nor *~
files. And that would make the trick. The problem is that i've a local_settings.py
file that I'd like to keep after the git clean.
So, this is what I've got.
.gitignore:
*.pyc
*~
local_settings.py
When I execute this command:
git clean -X -n -e local_settings.py
I get this list of results:
Would remove local_settings.py
Would remove requirements.txt~
Would remove (other bunch of) ~ files
Would remove (other bunch of) pyc files
I don't want to remove the local_settings.py file. I've tryed lots of ways to do it, but i can't figure out how to acomplish it.
git clean -X -n -e local_settings.py
git clean -X -n -e "local_settings.py"
git clean -X -n --exclude=local_settings.py
git clean -X -n --exclude="local_settings.py"
And nothing seems to work.
EDIT:
For posterity, the right way to do it is (Thanks @Rifat):
git clean -x -n -e local_settings.py # Shows what would remove (-n flag)
git clean -x -f -e local_settings.py # Removes it (note the -f flag)
Will you please try that with small x
instead of the capital one. Like - git clean -x
git clean -x -n -e local_settings.py # Shows what would remove (-n flag)
git clean -x -f -e local_settings.py # Removes it (note the -f flag)
From the git documentation:
-x Don't use the standard ignore rules read from .gitignore (per directory) and $GIT_DIR/info/exclude, but do still use the ignore rules given with -e options. This allows removing all untracked files, including build products. This can be used (possibly in conjunction with git reset) to create a pristine working directory to test a clean build. -X Remove only files ignored by git. This may be useful to rebuild everything from scratch, but keep manually created files.
git clean -X -n --exclude="!local_settings.py"
works. I discovered this when I googled and got this page.
I put local files that fall into this category in .git/info/exclude (e.g. my IDE project files). They you can do a clean like this:
git ls-files --others --exclude-from=.git/info/exclude -z | \
xargs -0 --no-run-if-empty rm --verbose
Where:
- --others: shows untracked files
- --exclude-from: provide a standard git ignore style file to exclude from the list
- -z / -0: use \0 instead of \n to split names
- --no-run-if-empty: Don't run rm if list is empty
You could create an alias, e.g.:
git config --global alias.myclean '!git ls-files --others --exclude-from=.git/info/exclude -z | xargs -0 --no-run-if-empty rm --verbose --interactive'
The --interactive means you have to do git myclean -f to force the deletion.
Reference: http://git-scm.com/docs/git-ls-files (plus the first line of the default .git/info/exclude)
If you're running Python 2.6+ just set the environment variable, PYTHONDONTWRITEBYTECODE
, to true
. You can just add the following to something like .profile
or .bashrc
to disable it entirely for your profile:
export PYTHONDONTWRITEBYTECODE=true
Or, if you just want to do that for a particular project you're working, you'll need to run the above in your shell each time (or in one of your virtualenv init scripts if you're using virtualenv and virtualenvwrapper), or you can simply pass the -B
parameter when you call python
, e.g.
python -B manage.py runserver
If you have commited the pyc's and so on already, do the following:
Add *.pyc, *~ and local_settings.py to the .gitignore. Then do in your git repository:
find . -name '*.pyc' | xargs rm
find . -name '*~' | xargs rm
then do:
git commit -am "get rif of them"
now they shouldn't bother you anymore
来源:https://stackoverflow.com/questions/11085795/git-exclude-a-file-with-git-clean