【shell】 1、bash语法超详细介绍
文章目录
- 修改前缀
- 路径
- dirname
- set
- 常用函数
- 参数
- 变量
- local
- 返回值
- 正则
- 打印第 n 行
- 获取行号
- 核对数据库各表数量
- jq
- 查询
- 检查日志
- sshpass
- expect
- 数组
- xargs

bash manual
修改前缀
参考
export PS1="bash> "
路径
dirname
strip last component from file name
dir=$(dirname "$0")EXAMPLESdirname /usr/bin/-> "/usr"dirname dir1/str dir2/str-> "dir1" followed by "dir2"dirname stdio.h-> "."
set
运行 bash script.sh 后会创建一个子 shell,可通过 set 命令对子 shell 的运行环境参数做查看和写入。其中可定制的参数有很多,详见 gnu shell manual
- 直接执行 set 会显示已设置的环境变量 和 shell 函数
- set -e:只要出错(即返回非 0 值)就停止运行
- set -o pipefail:set -e 对于含有管道的命令无效,加上个参数后,管道中任意命令出错都停止运行。
- 若
$?(表示上一次执行结果)非 0 则表示错误,如果希望忽略某些错误则可通过|| echo强行输出返回值为 0
- 若
- set -u:遇到未定义变量或方法时,停止运行
- set -x:执行每条命令前,输出命令原文
常用函数
ts=$(date +%s) # 获取日期,如1682072409
echo 'a:b' | cut -d ':' -f 2 # 截取第二项(下标从0开始)
tag=$(cat a.txt) # 命令的结果需要用"${}"包围
uri=www."${tag}".com # 字符串拼接时,需要用$包裹变量
参数
$0 表示文件名
$1 表示第一个参数
if ["x$1" == "x"] 语句是一个等式检查,查看 “x$1”(即变量$1前面加上一个x)是否等于 “x”。如果等于,说明变量$1是空的。
使用 “x$1” 的原因是为了防止某些特殊情况造成的问题。例如,当 $1 的值为一个开头为 “-” 的字符串时(例如 “-n”),如果不加 “x”,表达式会变成 "-n" == "",这可能会被shell解析为一个命令选项,而不是字符串比较,从而导致错误。
所以,["x$1" == "x"] 语句的含义就是检查变量$1是否为空,而且这种方式可以避免某些特殊情况下的错误。
变量
local
在shell脚本中,local是一种内建命令,用于在函数内部声明局部变量。这意味着这个变量的作用范围仅限于声明它的函数,一旦离开了该函数,这个变量就不再存在。
如果在函数内部没有使用local声明变量,那么这个变量就是全局的,可以在整个脚本中访问。
例如,考虑以下脚本:
#!/bin/bashfunction test_local() {local local_var="I'm local"global_var="I'm global"echo $local_varecho $global_var
}test_local
echo $local_var
echo $global_var
运行这个脚本的输出将是:
I'm local
I'm global
<空行>
I'm global
可以看到,local_var 在函数外部是不可见的,而 global_var 在整个脚本中都是可见的
返回值
if [ -z $plugin ]; then字符串是否为0’
正则
LeetCode193 bash题
打印第 n 行
grep -n "" file.txt | grep -w '10' | cut -d: -f2
sed -n '10p' file.txt
awk '{if(NR==10){print $0}}' file.txt
tail -n +10 file.txt | head -1
获取行号
row_num=$(cat file.txt | wc -l)
echo $row_num
if [ $row_num -lt 10 ];thenecho "The number of row is less than 10"
elseawk '{if(NR==10){print $0}}' file.txt
fi
核对数据库各表数量
# input_table.list
table1
table2
table3
table4
table5
#!/bin/bash
start=$(date -j -f "%Y-%m-%dT%H:%M:%S" "2022-02-21T00:00:00" "+%s")
end=$(date -j -f "%Y-%m-%dT%H:%M:%S" "2022-02-22T00:00:00" "+%s")
start=$(bc -e "$start*1000")
end=$(bc -e "$end*1000")
for i in $(cat input_table.list); doecho "$i"psql -h192.168.2.163 -p5432 -Upostgres -ddeepface_data -c "select count(1) from $i where ts >= $start and ts < $end"
done
jq
查询
{"FOO": {"name": "Donald","location": "Stockholm"},"BAR": {"name": "Walt","location": "Stockholm"},"BAZ": {"name": "Jack","location": "Whereever"}
}
# cat mytxt | jq .[] | jq ."name"
"Jack"
"Walt"
"Donald"# jq '.[] | select(.location=="Stockholm")' mytxt
{"name": "Donald","location": "Stockholm"
}
{"name": "Walt","location": "Stockholm"
}# jq -r .FOO.name mytxt # 查 json 某 key 对应的 value
Donald
检查日志
#!/bin/bash
# 过滤出.level = error, 但不含某些错误的日志
jq 'select(.level=="error")|select(.msg!="pq: no partition of relation found for row")|select(.msg!="json: cannot unmarshal object into Go struct field")' /logs/myprocess.err
sshpass
#!/bin/bash
set -x
app='a.txt b.json'
nodes=$(cat node.list)
password="qqq"
cd PKG
for i in $nodes; doip=$(echo $i| cut -d':' -f1)port=$(echo $i| cut -d':' -f2)sshpass -p "$password" scp -o StrictHostKeyChecking=no -P $port $app root@$ip:~/data
done
cd -
expect
expect 可以非交互式输入命令,设置如下 /Users/y/login.exp,然后 /Users/y/login.exp myname 192.168.2.99 mypass 即可ssh不需输入密-码,并且sudo -i不需输入密-码,简化操作。
➜ Desktop cat /Users/y/login.exp
#!/usr/bin/expectset timeout 3
spawn ssh [lindex $argv 0]@[lindex $argv 1]
expect {"(yes/no)?"{send "yes\n";exp_continue}"password:"{send "[lindex $argv 2]\n";exp_continue}"from"{send "sudo -i\n";}{send "sudo -i\n";exp_continue}"password:"{send "[lindex $argv 2]\n";}
}
interact
数组
参考
xargs
在 xargs 命令中,{} 是一个占位符,它表示 xargs 应该在哪里插入输入的参数。在使用 xargs 时,你可以用 -I 选项指定一个替代字符串,然后在命令行中的任何位置使用这个字符串,xargs 就会把这个字符串替换为从输入中读取的每个参数。
例如,以下命令:
echo '1 2 3' | xargs -I {} echo "Number: {}"
会输出:
Number: 1
Number: 2
Number: 3
如果你在同一条命令中使用了两个 {},xargs 会把它们都替换为相同的参数。例如,以下命令:
echo '1 2 3' | xargs -I {} echo "Number: {} and again: {}"
会输出:
Number: 1 and again: 1
Number: 2 and again: 2
Number: 3 and again: 3
在这个例子中,每一行都包含两个 {},xargs 会把它们都替换为相同的参数。
示例:批量删除 docker container
docker ps | grep unload | awk '{print $11}' | xargs -I {} docker rm -f {}
1. `docker ps`:列出所有运行中的 Docker 容器。
2. `grep unload`:从上述列表中找出含有 "unload" 的行。
3. `awk '{print $1}'`:从找到的行中提取出第一个字段(默认情况下,这是容器的 ID)。
4. `xargs -I {} docker rm -f {}`:对每一个找到的容器 ID,执行 `docker rm -f` 命令来强制移除容器。
相关文章:
【shell】 1、bash语法超详细介绍
文章目录 修改前缀路径dirname set常用函数参数变量local 返回值正则打印第 n 行获取行号核对数据库各表数量jq查询检查日志 sshpassexpect数组xargs bash manual 修改前缀 参考 export PS1"bash> "路径 dirname strip last component from file name dir$(…...
华清远见嵌入式学习——网络编程——作业3
目录 作业要求:基于UDP的TFTP文件传输 代码 下载功能效果图编辑 上传功能效果图 思维导图 模拟面试题和答案(定期更新) 作业要求:基于UDP的TFTP文件传输 完成文件的上传和下载功能 代码 #include<myhead.h>//实现…...
前端学习--React(3)
一、Redux 集中状态管理工具,不需要react即可使用,每个store的数据都是独立于组件之外的 vue小链接:vuex/pinia 基本使用 Redux将数据修改流程分成三个概念,state、action和reducer state - 一个对象 存放我们管理的数据状态 a…...
rotation matrix reflection matrix
文章目录 1. rotation matrix1.1 结论 2. reflection matrix2.1 结论 1. rotation matrix 图像逆时针旋转 θ \theta θ的矩阵 Q r o t a t e [ cos θ − sin θ sin θ cos θ ] (1) Q_{rotate}\begin{bmatrix}\cos\theta&-\sin\theta\\\sin\theta&\c…...
Python基础教程: sorted 函数
嗨喽,大家好呀~这里是爱看美女的茜茜呐 sorted 可以对所有可迭代的对象进行排序操作, sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。 从新排序列表。 👇 👇 👇 更多精彩机密、教程…...
Vue 重写push和replace方法,解决:Avoided redundant navigation to current location
当我们使用编程式路由导航跳转路径时,如果我们两次携带同样的参数进行跳转,会进行页面报错: 那产生这个问题的原因是什么呢? 我们接收并输出调用push方法返回的结果: 会发现这是一个Promise对象 我们都知道ÿ…...
43、vue导出pdf文件,并解决滚动条外内容无法获取的问题
使用插件html2canvas和jspdf插件 下载完两个插件后引入所需要的页面 import html2canvas from "html2canvas" import jsPDF from "jspdf"1、在导出之前将元素的高度或者宽度设置为滚动高度或者宽度,如: el.style.height el.scro…...
牛客 最小公配数 golang版实现
题目请参考: HJ108 求最小公倍数 题解: 在大的数的倍数里面去找最小的能整除另外一个数的数,就是最小公倍数,按照大的来找,循环次数能够降到很少,提升效率 golang实现: package mainimport ("fmt" )func main() {a : …...
用 HLS 实现 UART
用 HLS 实现 UART 介绍 UART 是一种旧的串行通信机制,但仍在很多平台中使用。它在 HDL 语言中的实现并不棘手,可以被视为本科生的作业。在这里,我将通过这个例子来展示在 HLS 中实现它是多么容易和有趣。 因此,从概念上讲…...
华清远见嵌入式学习——网络编程——作业4
作业要求:①使用IO多路复用中的select函数实现TCP并发服务器客户端 ②使用IO多路复用中的poll函数实现TCP并发服务器的服务器端 一、 代码 #include <myhead.h>#define SERPORT 8888 //服务器端口号 #define SERIP "192.168.114.113"…...
【OpenCV实现图像:制作酷炫的动画效果】
文章目录 概要生成背景图添加点动画添加文本显示小结 概要 首先,通过导入必要的库,包括NumPy用于数学运算和Matplotlib库用于数据可视化。随后,创建图形和轴,初始化点的位置,以及编写初始化函数和更新函数。 初始化函…...
CSS鼠标属性篇
属性名:cursor 功能:设置鼠标光标的样式 属性值: pointer:小手move:移动图标text:文字选择器crosshair:十字架wait:等待help:帮助 eg.html{ cursor: wait;}(此处使用css改…...
交直流一体化电源系统测试步骤详解
交直流一体化电源拥有高度适应性,可以用于不同的电力需求领域。但是为了确保其质量和性能,需要对交直流一体化电源进行各项测试以保证正常工作。本文纳米软件将介绍交直流一体化电源的测试方法,以及如何用交直流一体化电源测试系统进行测试。…...
多数据库使用django-apscheduler时,migrate后并不能生成django_apscheduler_djangojob表的问题
先说一下django-apscheduler定时器的使用过程: django-apscheduler基本使用 1.安装django-apscheduler代码如下(示例): pip install django-apscheduler 2.配置settings.py的INSTALLED_APPS代码如下(示例)…...
SPS简单对应分析
前言: 本专栏参考教材为《SPSS22.0从入门到精通》,由于软件版本原因,部分内容有所改变,为适应软件版本的变化,特此创作此专栏便于大家学习。本专栏使用软件为:SPSS25.0 本专栏所有的数据文件请点击此链接下…...
智能井盖传感器建设信息化时代智慧城市
近年来随着信息技术的快速发展和城市化进程的加速推进,智慧城市的概念逐渐成为现实。作为智慧城市生命线建设中的重要组成部分,智能井盖传感器的应用正在为城市的可持续发展和居民的生活质量提供新的解决方案。 智能井盖传感器能够实时监测井盖状态&…...
安装向量数据库milvus及其Attu
前置条件安装docker compose 在宿主机上创建文件目录 mkdir -p /home/sunyuhua/milvus/db mkdir -p /home/sunyuhua/milvus/conf mkdir -p /home/sunyuhua/milvus/etcd下载docker-compose.yml wget https://github.com/milvus-io/milvus/releases/download/v2.2.11/milvus-s…...
量子计算概述
目录 1.量子计算介绍 2.量子计算应用 3.量子计算研究机构 1.量子计算介绍 量子计算是一种遵循量子力学规律调控量子信息单元进行计算的新型计算模式。经典计算使用2进制进行运算,但2进制只有0和1两种状态,而量子计算除了包含0和1两种状…...
校园圈子论坛,交友,帖子内短视频,二手市场,APP小程序H5三端交付,源码交付,支持二开
校园圈子论坛,交友频道,商城,二手市场,活动专区,短视频,从校园生活的方方面面展现出了充满活力和创造力的镜头。这个频道是一个让学生们相互交流、结识新朋友的平台,不仅有交友功能,…...
Request 爬虫的 SSL 连接问题深度解析
SSL 连接简介 SSL(Secure Sockets Layer)是一种用于确保网络通信安全性的加密协议,广泛应用于互联网上的数据传输。在数据爬取过程中,爬虫需要与使用 HTTPS 协议的网站进行通信,这就牵涉到了 SSL 连接。本文将深入研究…...
深度对比:瑞芯微RK3588边缘盒子 vs 其他方案,在智慧油站车牌识别场景下的真实表现
智慧油站车牌识别实战:RK3588边缘计算盒子的性能突围战 当加油站开始拥抱智能化转型,车牌识别系统便成了连接物理世界与数字服务的"第一道闸机"。在华北某连锁油站的改造案例中,技术团队曾面临这样的困境:传统工控机处理…...
2026 年远程办公录音转文字工具横评:7 款产品分布式团队协作能力实测
一、引言随着分布式办公模式的普及,远程团队已成为互联网行业的常态。远程团队最大的协作痛点,是信息不同步、会议记录不全、讨论内容易遗漏、决策难追溯、知识沉淀弱,而一款适配远程办公场景的录音转文字工具,是打破远程信息孤岛…...
USB4转双10G SFP+适配器方案解析与选型指南
1. 为系统添加双10G SFP接口的USB4适配器方案解析在高速网络应用场景中,10GbE网络适配器已成为专业用户和发烧友的标配。传统的内置PCIe网卡虽然性能出色,但受限于主板插槽数量和空间布局。近期市场上出现的USB4转双10GbE SFP适配器,为移动工…...
Nanbeige 4.1-3B Node.js全栈开发:环境配置到项目部署
Nanbeige 4.1-3B Node.js全栈开发:环境配置到项目部署 1. 开篇:为什么选择Node.js全栈开发 如果你正在寻找一种既能快速上手又能构建高性能应用的技术方案,Node.js全栈开发绝对值得考虑。用JavaScript同时搞定前端和后端,这种统…...
如何重构漫画下载架构:基于Rust+Tauri的高性能异步下载引擎设计
如何重构漫画下载架构:基于RustTauri的高性能异步下载引擎设计 【免费下载链接】picacomic-downloader 哔咔漫画 picacomic pica漫画 bika漫画 PicACG 多线程下载器,带图形界面 带收藏夹,已打包exe 下载速度飞快 项目地址: https://gitcode…...
3步解锁微信聊天记录:WeChatExporter让你的数据真正属于你
3步解锁微信聊天记录:WeChatExporter让你的数据真正属于你 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 在iOS系统的封闭生态中,你是否曾为无法…...
GetNote开源数据抓取工具:智能解析与自动化内容收集实践
1. 项目概述:一个为“GetNote”而生的开源数据抓取利器如果你是一名笔记应用的重度用户,或者正在为团队寻找一个高效的信息收集与整理方案,那么“GetNote”这个名字你可能不会陌生。它是一个功能强大的笔记应用,以其出色的跨平台同…...
量子计算流体动力学:原理、挑战与噪声缓解策略
1. 量子计算流体动力学概述量子计算流体动力学(QCFD)是近年来兴起的前沿交叉领域,它试图利用量子计算机的独特优势来解决传统CFD方法面临的"维数灾难"问题。在经典计算机上,直接数值模拟(DNS)需要网格分辨率达到Kolmogo…...
Python 并发编程:最佳实践与性能
Python 并发编程:最佳实践与性能 核心原理 并发编程的基本概念 并发编程是指在同一时间内执行多个任务的编程范式,其核心目标是提高程序的执行效率和响应速度。在Python中,并发编程主要通过以下三种方式实现: 多线程(T…...
电钢琴核心技术与选购全攻略
在这篇文章中,我们将深入探讨电钢琴的核心技术,包括声源系统、键盘触感和音箱设计等方面。这些技术不仅影响着电钢琴的音质与演奏体验,还在很大程度上决定了你在选购时的优先考虑因素。了解这些技术特性可以帮助你在面对众多型号时作出更明智…...
