我如何在bash脚本中检索当前工作目录/文件夹名称,或者更好的是,仅仅是一个终端命令。
pwd给出了当前工作目录的完整路径,例如/opt/local/bin,但我只想要bin。
我如何在bash脚本中检索当前工作目录/文件夹名称,或者更好的是,仅仅是一个终端命令。
pwd给出了当前工作目录的完整路径,例如/opt/local/bin,但我只想要bin。
您可以使用pwd和basename的组合。如。
#!/bin/bash
CURRENT=`pwd`
BASENAME=`basename "$CURRENT"`
echo "$BASENAME"
exit;
不需要basename,特别是不需要运行pwd的子shell(这会增加额外且昂贵的fork操作);shell可以在内部使用参数展开:
result=${PWD##*/} # to assign to a variable
result=${result:-/} # to correct for the case where PWD=/
printf '%s\n' "${PWD##*/}" # to print to stdout
# ...more robust than echo for unusual names
# (consider a directory named -e or -n)
printf '%q\n' "${PWD##*/}" # to print to stdout, quoted for use as shell input
# ...useful to make hidden characters readable.
请注意,如果在其他情况下应用此技术(不是PWD,而是包含目录名的其他变量),则可能需要修剪任何尾随的斜杠。下面使用bash的extglob支持,即使使用多个尾随斜杠也能正常工作:
dirname=/path/to/somewhere//
shopt -s extglob # enable +(...) glob syntax
result=${dirname%%+(/)} # trim however many trailing slashes exist
result=${result##*/} # remove everything before the last / that still remains
result=${result:-/} # correct for dirname=/ case
printf '%s\n' "$result"
或者,不使用extglob:
dirname="/path/to/somewhere//"
result="${dirname%"${dirname##*[!/]}"}" # extglob-free multi-trailing-/ trim
result="${result##*/}" # remove everything before the last /
result=${result:-/} # correct for dirname=/ case
以下命令将在bash脚本中打印当前工作目录。
pushd .
CURRENT_DIR="`cd $1; pwd`"
popd
echo $CURRENT_DIR
我喜欢选择的答案(Charles Duffy),但如果您在符号链接目录中,并且想要目标目录的名称,请小心。不幸的是,我不认为它可以在一个参数展开表达式中完成,也许我错了。这应该可以工作:
target_PWD=$(readlink -f .)
echo ${target_PWD##*/}
为了验证这一点,我们做了一个实验:
cd foo
ln -s . bar
echo ${PWD##*/}
报告“酒吧”
目录名
显示路径的主目录(不触发/usr/bin/dirname的fork-exec命令):
echo ${target_PWD%/*}
这将转换foo/bar/baz -> foo/bar
可以使用basename实用程序从string中删除任何以/结尾的前缀和后缀(如果存在于string中),并打印 标准输出的结果。
$basename <path-of-directory>
令人惊讶的是,没有人提到这个只使用内置bash命令的替代方案:
i="$IFS";IFS='/';set -f;p=($PWD);set +f;IFS="$i";echo "${p[-1]}"
作为额外的奖励,你可以很容易地获得父目录的名称:
[ "${#p[@]}" -gt 1 ] && echo "${p[-2]}"
这些将在Bash 4.3 alpha或更新版本上工作。
我通常在sh脚本中使用它
SCRIPTSRC=`readlink -f "$0" || echo "$0"`
RUN_PATH=`dirname "${SCRIPTSRC}" || echo .`
echo "Running from ${RUN_PATH}"
...
cd ${RUN_PATH}/subfolder
你可以用它来自动化事情……
Use:
basename "$PWD"
OR
IFS=/
var=($PWD)
echo ${var[-1]}
将内部文件名分隔符(IFS)调回空格。
IFS=
在IFS后面有一个空格。
如果您只想看到bash提示符区域中的当前目录,可以在~中编辑.bashrc文件。在行中将\w改为\w:
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
执行source ~/。Bashrc,它只会在提示区域显示目录名。
裁判:https://superuser.com/questions/60555/show-only-current-directory-name-not-full-path-on-bash-prompt
有很多方法可以做到这一点,我特别喜欢Charles的方法,因为它避免了一个新的过程,但在知道这一点之前,我用awk解决了它
pwd | awk -F/ '{print $NF}'
只要删除任何字符直到/(或\,如果你在Windows上)。由于匹配将被设置为贪婪,它将删除直到最后一个/:
pwd | sed 's/.*\///g'
在你的情况下,结果是预期的:
λ a='/opt/local/bin'
λ echo $a | sed 's/.*\///g'
bin
只需执行以下命令行:
basename $(pwd)
如果你想复制这个名称:
basename $(pwd) | xclip -selection clipboard
basname示例的替代方案
pwd | grep -o "[^/]*$"
OR
pwd | ack -o "[^/]+$"
我的shell没有附带basename包,如果有办法的话,我倾向于避免下载包。