OS X 系统,使用 git 一次性导入大量文件,文件列表参数由程序自动生成, n 大于 4096 :
git add -- <file1> <file2> ... <filen>
运行命令出现错误:
too many arguments (6861) -- limit is 4096
git 高手们有遇到这种情况吗,该怎么解决?
1
Neytoph Apr 24, 2016 via iPhone “ git add .”你要的应该是这个....
|
3
SelFree Apr 24, 2016 =。= 6000+文件,看提示 limit is 4096 。这么多文件肯定不是手工整理的啦。分成多次或者导成 shell 呗:
git add <file1> git add <file2> ... |
4
ChiangDi Apr 24, 2016 via Android
分两次 add 呗
|
5
SelFree Apr 24, 2016
还有这个 4096 应该是 shell 的限制
|
7
SelFree Apr 24, 2016
@SelFree 一次 commit 就是你当前 add 的内容
git add file1 git add file2 git add filen git commit 这个时候就是 commit file1 、 file2 ... filen 啊 |
9
YuJianrong Apr 24, 2016 via iPhone
commit 不会有问题吧,不需要解决。
|
12
neoblackcap Apr 24, 2016
若是生成文件都在一个文件夹里面的话,你 add 那个文件夹就好了
|
13
sagnitude Apr 24, 2016
你既然知道哪些文件不想提交,剪切出来不就行了
|
14
loggerhead Apr 24, 2016 via iPhone 这跟 git 无关,是 shell 的限制,可以了解一下 xargs
|
15
lua OP |
16
xmgit Apr 24, 2016 不知道你不想提交的文件规律性怎么样,有个暴力的办法,列出你不想 commit 的文件, echo 进.gitignore 里
等 commit 后,再从.gitignore 里删除掉 |
19
bikong0411 Apr 24, 2016
这是 shell 报的错,跟 git 无关
|
20
lizheming Apr 24, 2016
如果是添加的多,不想添加的只有几个,可以 git add . 之后然后 git reset file 。当然我更推荐的是使用 git add -i 进入交互模式,可以自行选择需要 add 的文件,非常方便。
|
21
owlsec Apr 24, 2016 .gitignore
|
22
xiamx Apr 24, 2016
echo "<file1> <file2> <filen>" | xargs git add --
|
23
327beckham Apr 24, 2016
你既然能整理出<file1> <file2> <file3> 。。。。这么长的列表,那就再弄一个 bash 脚本,内容是:
git add <file1> git add <file2> git add <file3> ...... |
25
mengzhuo Apr 24, 2016
shell 的问题怎么能怪 git 呢
楼主的结构有问题了吧 |
26
sunjourney Apr 24, 2016 via iPhone
这么多文件真的是项目文件吗?什么东西的源码会这样?编译后的东西不要同步了好吧?
|
27
Clarencep Apr 24, 2016
如果不想提交的文件比较少,可以先 `git add .` 然后使用 `git reset HEAD 不想提交的文件` 来排除
|
28
Ixizi Apr 24, 2016
把要改的随便加点注释之类的,然后 git add -u
|
29
Kirscheis Apr 24, 2016 via Android
这是 shell 的问题,和 git 没关系。 echo " " | xargs git add -- 就好了
|
30
wizardoz Apr 24, 2016
同觉得问题不存在,不想 commit 的文件不要 add 就行了,又要 add 又不想 commit 的理由是什么?
|
32
itfanr Apr 24, 2016
git add -A
|
33
kxxoling Apr 24, 2016
git add . ;git rm xxx --cached?
|
34
kxxoling Apr 24, 2016
没提交的话 git add .; git reset xxx 应该也行。话说这么多文件就不能用通配符?
|
35
xwartz Apr 24, 2016
git add --all
|
36
marcushbs Apr 24, 2016
function gc {
for f in `git status |grep modified|awk '{print $3}'` do git add $f done git commit -m "$1" git push } |
37
billlee Apr 24, 2016
你需要 xargs
|
38
hzlzh PRO 之前做 temp.im 这个服务的时候尝试过 push 100w 个文件到 github 上,是分批进行的, github 有做限制。
via https://study.congcong.us/t/57477 后来换七牛 CDN 来存了 |
39
BOYPT Apr 24, 2016
命令行长度是内核限制来的。跟 git 无关
|
40
bicoff9527 Apr 24, 2016
奇怪的想法,大概是对 git 不熟
|
41
Haku Apr 24, 2016
too many arguments 是指参数太多,也就是命令用错的意思....
|
42
tsl0922 Apr 24, 2016
如果想忽略当前 index 内容只提交特定文件可以使用: git commit --only -m <msg> -- <file>...
|
43
strwei Apr 24, 2016
git add -A
|
44
mhtt Apr 24, 2016 via iPhone
git add -A ?
|
45
cheerzeng Apr 24, 2016
如果是同类文件,以 python 文件为例,可以 git add *.py
至于 commit ,跟 add 几次没关系啊 |
46
pynix Apr 24, 2016
分成 2 批。。。
|
47
wensonsmith Apr 24, 2016
git add -A
|
48
starcraft Apr 24, 2016 via iPhone
今天也碰到了添加的问题 刚好搜了研究下-A 的命令
|
49
kirisetsz Apr 24, 2016
这个是 shell 或者系统调用的限制解法嘛,把结果导入 xargs 转换一下吧 find . -print0 -type f | xargs -n1 git add -- 这样。
|
50
busyluo Apr 25, 2016 via iPhone
|
51
chuxiwen Apr 25, 2016 via iPad
too many arguments (6861) -- limit is 4096
这个是 shell 的限制,可以自写个 shell script 克服这个问题 http://stackoverflow.com/questions/13781216/bash-meaning-of-too-many-arguments-error-from-if-square-brackets |
52
allenforrest Apr 25, 2016
感觉是做文件云同步,底层机制用 git 实现
|
53
darasion Apr 25, 2016
是 shell 的限制。即便你不用 git ,删除这么多文件也是有问题的。
一般命令行参数太多了或者不能预期是多少的时候,都得用 xargs 命令展开一下。 |
54
SmiteChow Apr 25, 2016
顶楼上,楼上说的展开就是走管道,妥妥的没问题
|