我已经知道如何在给定目录中执行此操作:
for file in *.png; do
mv -- "$file" "$RANDOM-$RANDOM-$RANDOM.png"
done
如何将其变成递归命令?
我已经知道如何在给定目录中执行此操作:
for file in *.png; do
mv -- "$file" "$RANDOM-$RANDOM-$RANDOM.png"
done
如何将其变成递归命令?
经过一番搜索,我想出了这个命令:
> find . -type f \( -name "*.exe" \) | egrep -v
> 'games_1|rei|games|tor|jogos|mods|text' > 1
我想要做的是查找扩展名为 .exe 的文件,但包含任何这些字符串的路径除外,然后将结果打印到名为“1”的文件中,我将其写入可执行文件。
但是,在终端中执行时,出现以下错误并且没有执行任何操作:
find: ‘./NUNO-PC/Disco_2TB_120323/Downloads_070321/My Web Sites/wdsdeewre/2.bp.blogspot.com’: Input/output error
find: ‘./NUNO-PC/Disco_2TB_120323/Downloads_070321/My Web Sites/wdsdeewre/segredoh.blogspot.com/feeds’: Input/output error
find: ‘./NUNO-PC/Disco_2TB_120323/Downloads_070321/My Web Sites/wdsdeewre/4.bp.blogspot.com’: Input/output error
find: ‘./NUNO-PC/Disco_2TB_120323/Downloads_070321/My Web Sites/wdsdeewre/3.bp.blogspot.com/-ux8HFQj0iuE/WQ9ywGiPXOI’: Input/output error
grep: write error: Input/output error
./encontrarsoft: error reading input file: Invalid argument
我缺少什么?
我只能使用ls -a列出目录本身,或者使用ls -aR按目录排序的文件
我希望自动压缩目录中每个子文件夹的内容(不包括子文件夹本身),其中所述内容的每个 .zip 对应于每个子文件夹。有没有办法在 Ubuntu 22.04 中做这样的事情?由 .zip 文件组成的输出可能位于每个子文件夹中,也可能位于某个位置中的所有子文件夹中,我不在乎。
示例:代码将读取/获取子文件夹 1 的内容并对其进行压缩,然后对子文件夹 2 执行相同的操作,依此类推。
我在网上搜索了这个问题,并在堆栈交换中找到了一个有关问题的代码,该代码被誉为解决此问题的方法。但是,当我在终端中运行时,输出是这样的:
*Possible Dupes
Which dupe would you like to delete?
Enter # to delete or q to quit
#
./3: line 36: [: #: integer expression expected
./3: line 36: [: #: integer expression expected
./3: line 43: #: syntax error: operand expected (error token is "#")*
如果我没有它们的列表,我怎么知道“我想删除”哪个骗局?所以,对我来说根本没有解决办法。我不知道该怎么办。哦,“去读一些手册”没有帮助。
我有 3255 个文件需要筛选,我不想花几个小时从头到尾查看每个文件,我不想查找是否存在特定的重复项,而是想查找是否有任何文件名在第一个 X 中重复(可以1,2 或更多)字符,这样我就可以删除它们,无论是泡泡龙、凯撒、弹球梦还是其他什么。我想从 A 到 Z 的 3255 个文件中查找哪些文件在第一个字符中重复,并指定我要查找的字符数。
我不想重命名任何东西。
文件名示例:
Perfect General The (1991)(Ubisoft Entertainment).7z
Boulderdash 2 (1985)(First Star Software).7z
Bridge 7.0 (1992)(Artworx).7z
预期输出:
Bubble Bobble (1987)(Taito Corporation).7z
Bubble Bobble (1990)(Taito Corporation).7z
我不希望代码删除任何内容,我只是希望它为我找到相关文件。
代码:
#!/bin/bash
declare -a names
xIFS="${IFS}"
IFS="^M"
while true; do
awk -F'[-_ ]' '
NR==FNR {seen[tolower($1)]++; next}
seen[tolower($1)] > 1
' <(printf "%s\n" *.jar) <(printf "%s\n" *.jar) > tmp.dat
IDX=0
names=()
readarray names < tmp.dat
size=${#names[@]}
clear
printf '\nPossible Dupes\n'
for (( i=0; i<${size}; i++)); do
printf '%s\t%s' ${i} ${names[i]}
done
printf '\nWhich dupe would you like to delete?\nEnter # to delete or q to quit\n'
read n
if [ $n == 'q' ]; then
exit
fi
if [ $n -lt 0 ] || [ $n -gt $size ]; then
read -p "Invalid Option: present [ENTER] to try again" dummyvar
continue
fi
#clean the carriage return \n from the name
IFS='^M'
read -ra TARGET <<< "${names[$n]}"
unset IFS
# now remove the filename sans any carriage returns
# from the filesystem
# 12/18/2020
rm "${TARGET[*]}"
echo "removed ${TARGET[0]}" >> rm.log
done
IFS="${xIFS}"