ale*_*333 4 bash shell gzip tar
我有一个数组,其中包含我希望添加到压缩tar(tar.gz)的文件和目录.最初我打算遍历数组并将每个项目添加到tar中,类似于:
tar czf my_app.tar.gz
for app_item in "${app_items[@]}"
do
tar rzf my_app.tar.gz $app_item
done
Run Code Online (Sandbox Code Playgroud)
运行脚本我发现我无法将文件添加到压缩的tar中.我想知道是否还有其他方法可以从我的数组列表中创建一个tar.
任何帮助将不胜感激!
该问题仅存在于压缩档案中.我建议首先创建和使用未压缩的存档,然后在循环运行时压缩它.
tar cf my_app.tar --files-from /dev/null
for app_item in "${app_items[@]}"
do
tar rf my_app.tar "$app_item"
done
gzip my_app.tar
Run Code Online (Sandbox Code Playgroud)
正如@Matthias在评论中所指出的,创建一个空档案(我们想要的第一行)通常被拒绝tar
.为了强制它这样做,我们需要一个与操作系统不同的技巧:
tar cf empty.tar --from-file /dev/null
tar cvf empty.tar --files-from /dev/null
tar cvf empty.tar -I /dev/null
关于此的更多细节解释了他链接到的页面.
一种完全不同的方法似乎与文件名中的空格很好地配合(但不包含带有换行符的文件名,所以它不是那么通用):
tar cfz my_app.tgz --files-from <(printf "%s\n" "${app_items[@]}")
Run Code Online (Sandbox Code Playgroud)
还有另一种方法(这也适用于文件名中的换行符和其他内容:
eval tar cfz my_app.tgz $(printf "%q " "${app_items[@]}")
Run Code Online (Sandbox Code Playgroud)
但是和往常一样,eval
你应该知道你传递给它的是什么,并且这些都不是来自不受信任的来源,否则它可能会带来安全问题,所以一般来说我建议避免它.