1

我正在创建一个在 OS X 上运行的脚本,该脚本将由新手用户经常运行,因此希望通过每次创建一个新的目录结构来保护目录结构,最后一个 n+1:

target001下一次运行创建target002

我到目前为止:

lastDir=$(find /tmp/target* | tail -1 | cut -c 6-)
let n=$n+1
mkdir "$lastDir""$n"

但是,数学在这里不起作用。

4

5 回答 5

2

怎么样 mktemp

安全地创建一个临时文件或目录,并打印其名称。
TEMPLATE 必须在最后一个组件中包含至少 3 个连续的“X”。
如果没有指定 TEMPLATE,使用 tmp.XXXXXXXXXX,--tmpdir 是
默示。创建文件 u+rw,目录 u+rwx,减去 umask
限制。
于 2013-04-26T03:47:56.490 回答
2

使用这一行来计算新的序列号:

...
n=$(printf "%03d" $(( 10#$n + 1 )) )
mkdir "$lastDir""$n"

10#强制以10为底的算术。已经提供了 $n 的最后一个 secuence,例如“001”。

于 2013-04-26T07:04:31.197 回答
1

没有管道和子进程:

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
于 2013-04-26T08:10:22.473 回答
1

使用扩展测试 [[ 和 BASH_REMATCH 的完整解决方案:

[[ $(find /tmp/target* | tail -1) =~ ^(.*)([0-9]{3})$ ]]
mkdir $(printf "${BASH_REMATCH[1]}%03d" $(( 10#${BASH_REMATCH[2]} + 1 )) )

提供 /tmp/target001 是您的目录模式。

于 2013-04-26T15:12:19.107 回答
0

像这样:

lastDir=$(find /tmp/target* | tail -1)
let n=1+${lastDir##/tmp/target}
mkdir /tmp/target$(printf "%03d" $n)
于 2013-04-26T05:01:03.137 回答