极大提高工作效率的 Linux 命令
共 6336字,需浏览 13分钟
·
2024-06-16 08:10
原文链接:https://www.linuxmi.com/linux-commands-for-improving-work-efficiency.html
自定义bash提示符
linuxmi@linuxmi:~/www.linuxmi.com$ export PS1="[\u@\W]\$"
# 查找文件:
find ~ -type f -name data-model.ts
# 查找文件夹:
find ~ -type d -name angular15
#查找所有.html文件并计算每个文件的行数:
find src/app/ -name "*.html" -exec wc -l {} \;
find src/app/ -name "*.html" -exec wc -l {} +
更改文件和文件夹的权限
# 与其他人共享文件夹,以便他们可以检查文件夹中的内容:
chmod 755 <path-to-your-folder>
# 与其他人共享不可执行文件:
chmod 644 <path-to-your-file>
# 与其他人共享可执行文件:
chmod 755 <path-to-your-file>
# 使文件只读:
chmod 400 <path-to-your-file>
# 使文件可执行:
chmod +x <path-to-your-file>
自定义 rm 命令将文件移动到回收站
alias rm='gio trash'
使用别名可以简化输入
# 为长命令设置别名:
alias dc="docker compose"
alias prettier="npx prettier -w"
alias eslint="npx eslint --fix"
alias pre="pre-commit run --files"
# 将一些命令链接在一起:
alias update-container="docker-compose pull <service-name> && docker-compose stop <service-name> && yes | docker-compose rm <service-name> && docker-compose up -d <service-name>"
使用awk从输入中提取数据
awk是Linux中非常强大的工具。你甚至可以使用awk编写脚本,尽管可读性和维护性是另外一个问题。作为软件开发人员,我们通常使用awk从输入文件或前一个命令的输出中获取所需的字段。
ping google.com -c 2 | grep -iE 'time=.*ms' | awk 'BEGIN {FS="="} {print $NF}'
-
我们使用-iE来为grep指定一个正则表达式,因此只有与模式匹配的消息将进一步处理。 -
对于awk来说,BEGIN指定在处理文本之前要执行的命令。在这里,我们指定字段分隔符(FS)应为等号。此外,NF表示字段的数量,$NF将返回最后一个字段。如果你想进一步学习awk,这是一个很好的参考。
ping google.com -c 2 | grep -iE 'time=.*ms' | awk -F"=" '{print $NF}'
ping google.com -c 2 | awk -F"=" '/time=.*ms/ {print $NF}'
-
可以直接使用 -F 选项指定字段分隔符。 -
可以在 awk 中使用正则表达式模式,在花括号之前指定。
使用 xargs 链接命令
# 检查当前文件夹中每个文件的大小:
ls | xargs -I % du -sh %
# 查找一些文件并将其复制到新位置:
find ~/Downloads/ -name "*.jpeg" | xargs -I {} cp {} ~/Pictures/
# 将所有文件夹和子文件夹的权限更改为755:
find . -type d | xargs -I {} chmod 755 {}
# 将当前文件夹和子文件夹中所有文件的权限更改为644:
find . -type f | xargs -I {} chmod 644 {}
为脚本传递变量
# linuxmi.sh
echo mysql -u ${USERNAME} -p${PASSWORD}
# 在命令行上:
USERNAME=johndoe PASSWORD=12345 bash some_script.sh
# variables.env
USERNAME=johndoe
PASSWORD=12345
# 在命令行上:
env $(grep -v '^#' variables.env | xargs) bash some_script.sh
重定向STDOUT和STDERR
# 让我们假设existing.txt存在,而nonexisting.txt不存在。
# 将STDOUT重定向到文件。这是最常见的用例。
ls -al existing.txt 1>out.log
# STDOUT的文件描述符是可选的。
ls -al existing.txt >out.log
# 将STDOUT重定向到一个文件,将STDOUT重定向到另一个文件。
ls -al existing.txt non-existing.txt 1>out.log 2>error.log
# 将STDOUT和STDERR都指向同一个文件:
ls -al existing.txt non-existing.txt 1>combined.log 2>&1
# 它可以简化为:
ls -al existing.txt non-existing.txt &>combined.log
# 忽略命令的输出和错误:
ls -al existing.txt non-existing.txt 1>/dev/null 2>&1
ls -al existing.txt non-existing.txt &>/dev/null
命令行模糊查找器
# Linux:
git clone --depth 1 https://github.com/junegunn/fzf.git ~/.fzf
~/.fzf/install # 您可以接受所有默认设置.
# MacOS:
brew install fzf
$(brew --prefix)/opt/fzf/install
评论