我如何在bash脚本中检索当前工作目录/文件夹名称,或者更好的是,仅仅是一个终端命令。

pwd给出了当前工作目录的完整路径,例如/opt/local/bin,但我只想要bin。


使用basename程序。对于你的情况:

% basename "$PWD"
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

$ echo "${PWD##*/}"

​​​​​


以下命令将在bash脚本中打印当前工作目录。

pushd .
CURRENT_DIR="`cd $1; pwd`"
popd
echo $CURRENT_DIR

这个帖子很棒!这里还有一种味道:

pwd | awk -F / '{print $NF}'

我喜欢选择的答案(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


echo "$PWD" | sed 's!.*/!!'

如果您正在使用Bourne shell或${pwd# #*/}不可用。


可以使用basename实用程序从string中删除任何以/结尾的前缀和后缀(如果存在于string中),并打印 标准输出的结果。

$basename <path-of-directory>

basename $(pwd)

or

echo "$(basename $(pwd))"

只使用:

pwd | xargs basename

or

basename "`pwd`"

那么grep呢:

pwd | grep -o '[^/]*$'

令人惊讶的是,没有人提到这个只使用内置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

你可以用它来自动化事情……


下面grep with regex也可以,

>pwd | grep -o "\w*-*$"

对于像我这样的骑手来说

find $PWD -maxdepth 0 -printf "%f\n"

我强烈倾向于使用gbasename,它是GNU coreutils的一部分。


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包,如果有办法的话,我倾向于避免下载包。