在Git中合并python文件时会出现错误。请分享您的想法。如何删除所有pyc文件并合并内容。从存储库中提取更新时会发生此错误。那些pyc文件经常更新。当我从存储库中提取更新时,每次都会发生错误
error: The following untracked working tree files would be overwritten by merge:
addressbook/views.pyc
allauth/account/admin.pyc
allauth/account/auth_backends.pyc
allauth/account/context_processors.pyc
allauth/account/forms.pyc
allauth/account/management/__init__.pyc
allauth/account/urls.pyc
allauth/account/views.pyc
allauth/exceptions.pyc
allauth/socialaccount/adapter.pyc
allauth/socialaccount/admin.pyc
allauth/socialaccount/app_settings.pyc
allauth/socialaccount/context_processors.pyc
allauth/socialaccount/forms.pyc
allauth/socialaccount/helpers.pyc
allauth/socialaccount/providers/base.pyc
allauth/socialaccount/providers/facebook/forms.pyc
allauth/socialaccount/providers/facebook/locale.pyc
allauth/socialaccount/providers/facebook/provider.pyc
allauth/socialaccount/providers/facebook/urls.pyc
allauth/socialaccount/providers/facebook/views.pyc
allauth/socialaccount/providers/google/provider.pyc
allauth/socialaccount/providers/google/urls.pyc
allauth/socialaccount/providers/google/views.pyc
allauth/socialaccount/providers/linkedin/provider.pyc
allauth/socialaccount/providers/linkedin/urls.pyc
allauth/socialaccount/providers/linkedin/views.pyc
allauth/socialaccount/providers/oauth/__init__.pyc
allauth/socialaccount/providers/oauth/client.pyc
allauth/socialaccount/providers/oauth/provider.pyc
allauth/socialaccount/providers/oauth/urls.pyc
allauth/socialaccount/providers/oauth/views.pyc
allauth/socialaccount/providers/oauth2/__init__.pyc
allauth/socialaccount/providers/oauth2/client.pyc
allauth/socialaccount/providers/oauth2/provider.pyc
allauth/socialaccount/providers/oauth2/urls.pyc
allauth/socialaccount/providers/oauth2/views.pyc
allauth/socialaccount/providers/twitter/provider.pyc
allauth/socialaccount/providers/twitter/urls.pyc
allauth/socialaccount/providers/twitter/views.pyc
allauth/socialaccount/signals.pyc
allauth/socialaccount/urls.pyc
allauth/socialaccount/views.pyc
allauth/urls.pyc
crispy_forms/base.pyc
crispy_forms/bootstrap.pyc
crispy_forms/exceptions.pyc
crispy_forms/helper.pyc
crispy_forms/layout.pyc
crispy_forms/layout_slice.pyc
crispy_forms/utils.pyc
feeds/views.pyc
lettertemplate/forms.pyc
lettertemplate/views.pyc
quorum/forms.pyc
quorum/views.pyc
registration/admin.pyc
registration/forms.pyc
registration/models.pyc
registration/urls.pyc
registration/views.pyc
rosetta/polib.pyc
rosetta/poutil.pyc
rosetta/signals.pyc
rosetta/storage.pyc
rosetta/urls.pyc
rosetta/views.pyc
Please move or remove them before you can merge.
Aborting
答案 0 :(得分:6)
.pyc
个文件,因为正如您所见,它们会不断变化。通常,构建产品不会存储在git中。如果你有选择我会在上游存储库中解开它们。
如果这不是一个选项,您唯一的选择是移动或删除您的本地.pyc
文件。您可以使用以下命令执行此操作(注意:这假设您要删除当前目录下或之下的所有 .pyc
文件。
find . -iname '*.pyc' -exec rm {} \;
执行此操作后,您应该可以进行合并,因为不会覆盖本地文件。
答案 1 :(得分:5)
发生此错误是因为您正在跟踪存储库中的.pyc
文件(您不应该这样做)。这可能是git add .
的结果。您应该做的是删除.pyc
所有git rm
个文件,然后再次合并。 Git不会抱怨,因为它不会通过本地版本复制存储库.pyc
文件。
正如Nick建议的那样,添加.pyc
和其他无意义的文件来跟踪全局(或存储库级别).gitignore
可能是一个好主意。如果您这样做,git add .
将不会自动添加这些文件。查看GitHub's official list of suggested .gitignore
files。
答案 2 :(得分:1)
要从索引中删除这些文件,请使用:
find . -name *.pyc | xargs rm
然后你可以在.gitgnore
*.py[cod]
一旦你告诉git忽略这些文件,你将不再收到警告信息。
我更喜欢忽略我的" global"中的编译文件。 gitignore文件(更多关于here的信息),但您也可以在每个存储库的基础上执行此操作。