为 Python 项目添加 .gitignore 文件的最佳实践? [关闭]

Posted

技术标签:

【中文标题】为 Python 项目添加 .gitignore 文件的最佳实践? [关闭]【英文标题】:Best practices for adding .gitignore file for Python projects? [closed] 【发布时间】:2011-04-12 18:22:27 【问题描述】:

我正在尝试收集一些默认设置,但我意识到我没有标准的一件事是 .gitignore 文件。有一个很棒的线程显示good .gitignore for Visual Studio projects,但我没有看到很多关于 Python 和相关工具(PyGTK、Django)的建议。

到目前为止,我已经...

*.pyc
*.pyo

...对于已编译的对象和...

build/
dist/

...用于 setuptools 输出。

.gitignore 文件有哪些最佳做法,我可以从哪里获得有关这些最佳做法的更多信息?

【问题讨论】:

这个项目github.com/github/gitignore 旨在准确回答这个问题。 .. 只是不要忘记添加github.com/github/gitignore/blob/master/Python.gitignore,因为它也是一个 python 项目。 进入 gitignore.io 并输入 python 获取标准文件, 由于问题已关闭,我在这里评论我认为应该是答案的内容。如果您在 PyCharm IDE 上,您可能需要忽略 .idea/ 目录。这取决于您是否要共享一些/所有项目设置。 Here's关于这个的问题 我真的很讨厌这些“基于意见”的问题被关闭。为什么??这不是一个敏感的话题,会引发激烈的战争。没有人会因为承认不同的意见而感到不安。 OP(和我)只是想要一些最佳实践指南,并且很高兴认识到它们不可能“正确”,但仍然非常有用。 【参考方案1】:

涵盖了大部分常规内容 -

# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class

# C extensions
*.so

# Distribution / packaging
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
*.egg-info/
.installed.cfg
*.egg
MANIFEST

# PyInstaller
#  Usually these files are written by a python script from a template
#  before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec

# Installer logs
pip-log.txt
pip-delete-this-directory.txt

# Unit test / coverage reports
htmlcov/
.tox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*.cover
.hypothesis/
.pytest_cache/

# Translations
*.mo
*.pot

# Django stuff:
*.log
local_settings.py
db.sqlite3

# Flask stuff:
instance/
.webassets-cache

# Scrapy stuff:
.scrapy

# Sphinx documentation
docs/_build/

# PyBuilder
target/

# Jupyter Notebook
.ipynb_checkpoints

# pyenv
.python-version

# celery beat schedule file
celerybeat-schedule

# SageMath parsed files
*.sage.py

# Environments
.env
.venv
env/
venv/
ENV/
env.bak/
venv.bak/

# Spyder project settings
.spyderproject
.spyproject

# Rope project settings
.ropeproject

# mkdocs documentation
/site

# mypy
.mypy_cache/

参考:python .gitignore

【讨论】:

这个上面已经提到了! @Emmanuel 另一个答案中提到的不是通用样板文件,它有很多不必要的东西。这里提到的一般适用于任何 Django/python。 确实,很抱歉……不幸的是,在编辑答案之前我无法取消我的反对票……【参考方案2】:

Github has a great boilerplate .gitignore

# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]

# C extensions
*.so

# Distribution / packaging
bin/
build/
develop-eggs/
dist/
eggs/
lib/
lib64/
parts/
sdist/
var/
*.egg-info/
.installed.cfg
*.egg

# Installer logs
pip-log.txt
pip-delete-this-directory.txt

# Unit test / coverage reports
.tox/
.coverage
.cache
nosetests.xml
coverage.xml

# Translations
*.mo

# Mr Developer
.mr.developer.cfg
.project
.pydevproject

# Rope
.ropeproject

# Django stuff:
*.log
*.pot

# Sphinx documentation
docs/_build/

【讨论】:

我们为什么要忽略 *.mo 文件?只是为了好奇。那些gettext的.po文件是在服务器上单独编译的吗? .mo 文件是 .po 文件的机器可读(二进制)版本,并且 - 众所周知 - 如果可以(并且你应该,因为同时包含 .po 和 .mo 意味着在存储库中保留重复的数据,VCS 甚至不能“压缩”) 为什么不使用 .DS_Store? 我真的很困惑为什么他们在.gitignore 中有.python-version:github.com/github/gitignore/blob/master/Python.gitignore#L82【参考方案3】:

当使用buildout 时,我在.gitignore 中有关注(以及*.pyo*.pyc):

.installed.cfg
bin
develop-eggs
dist
downloads
eggs
parts
src/*.egg-info
lib
lib64

感谢Jacob Kaplan-Moss

我也倾向于输入.svn,因为我们在我工作的地方使用了几个 SCM-s。

【讨论】:

将 svn 存储库与您的 git 存储库保存在同一棵树中!?什么样的怪物会做出这种事? @Daenyth giggle,不是真的,但如果我从其他来源获取组件(特别是在旧组件中),我倾向于找到一些剩余的 .svn 目录而且我也很懒所以我有时会复制结帐而不是从 SVN 导出东西。我曾经什至看到一个人实际上在 GIT 中提交了剩余的 .svn 目录。与愚蠢的人一起工作时,您可能会遇到各种奇怪的事情。 好吧,我正试图将它们挂在 *** 上...:p 我还没有使用 Buildout,但可能很快就会需要......所以我会把它们放在列表中。谢谢! 您应该将*.svn 放入您的.global_gitignore,而不是单独的项目中。【参考方案4】:

以下是 setuptools 可能留下的其他一些文件:

MANIFEST
*.egg-info

【讨论】:

我想我可能会将这些排除在我的默认设置之外,因为我的一些项目具有需要它们的 setuptools 发行版。但是对于插件等,是的。【参考方案5】:

local_settings.py,用于 django 项目。

*~ 适用于所有项目。

【讨论】:

这是有道理的。我喜欢这种将通用配置与特定/本地/私有分开的方法。 这是如何工作的?也就是Django或者Python如何知道环境什么时候是本地的,什么时候是生产环境的?【参考方案6】:

一个问题是您是否还想使用 git 来部署您的项目。如果是这样,您可能希望从存储库中排除本地 sqlite 文件,同样可能适用于文件上传(主要在您的媒体文件夹中)。 (我现在说的是 django,因为你的问题也用 django 标记)

【讨论】:

明白。由于 Django 不强制执行很多文件名和目录结构,因此很难提前指定这些。但我至少可以记下它,以便我记得我何时创建一个新项目。 好吧,你至少应该让所有用户上传的文件都放在媒体目录的一个文件夹中,例如。 media/uploads,所以你可以用一条规则“忽略”它们……

以上是关于为 Python 项目添加 .gitignore 文件的最佳实践? [关闭]的主要内容,如果未能解决你的问题,请参考以下文章

Git 的 .gitignore 配置

`.gitignore` 用于具有 Android 目标的 Ionic 项目

iOS 项目添加gitignore 文件

Git忽略规则.gitignore梳理

Git忽略规则.gitignore梳理

Git忽略规则.gitignore梳理