我正在创建一个在 OS X 上运行的脚本,该脚本将由新手用户经常运行,因此希望通过每次创建一个新的目录结构来保护目录结构,最后一个 n+1:
target001
下一次运行创建target002
我到目前为止:
lastDir=$(find /tmp/target* | tail -1 | cut -c 6-)
let n=$n+1
mkdir "$lastDir""$n"
但是,数学在这里不起作用。
怎么样
mktemp
?
安全地创建一个临时文件或目录,并打印其名称。 TEMPLATE 必须在最后一个组件中包含至少 3 个连续的“X”。 如果没有指定 TEMPLATE,使用 tmp.XXXXXXXXXX,--tmpdir 是 默示。创建文件 u+rw,目录 u+rwx,减去 umask 限制。
使用这一行来计算新的序列号:
...
n=$(printf "%03d" $(( 10#$n + 1 )) )
mkdir "$lastDir""$n"
10#强制以10为底的算术。已经提供了 $n 的最后一个 secuence,例如“001”。
没有管道和子进程:
targets=( /tmp/target* ) # all dirs in an array
lastdir=${targets[@]: (-1):1} # select filename from last array element
lastdir=${lastdir##*/} # remove path
lastnumber=${lastdir/target/} # remove 'target'
lastnumber=00$(( 10#$lastnumber + 1 )) # increment number (base 10), add leading zeros
mkdir /tmp/target${lastnumber: -3} # make dir; last 3 chars from lastnumber
具有 2 个参数的版本:
path='/tmp/x/y/z' # path without last part
basename='target' # last part
targets=( $path/${basename}* ) # all dirs in an array
lastdir=${targets[@]: (-1):1} # select path from last entry
lastdir=${lastdir##*/} # select filename
lastnumber=${lastdir/$basename/} # remove 'target'
lastnumber=00$(( 10#$lastnumber + 1 )) # increment number (base 10), add leading zeros
mkdir $path/$basename${lastnumber: -3} # make dir; last 3 chars from lastnumber
使用扩展测试 [[ 和 BASH_REMATCH 的完整解决方案:
[[ $(find /tmp/target* | tail -1) =~ ^(.*)([0-9]{3})$ ]]
mkdir $(printf "${BASH_REMATCH[1]}%03d" $(( 10#${BASH_REMATCH[2]} + 1 )) )
提供 /tmp/target001 是您的目录模式。
像这样:
lastDir=$(find /tmp/target* | tail -1)
let n=1+${lastDir##/tmp/target}
mkdir /tmp/target$(printf "%03d" $n)