【shell编程】函数、正则表达式、文本处理工具
函数
系统函数
常见内置命令
echo打印输出
#!/bin/bash
# 输出普通文本
echo "Hello, World!"# 输出变量值
name="Alice"
echo "Hello, $name"# 输出带有换行符的文本
echo -n "Hello, " # -n 选项不输出换行
echo "World!"
cd :改变当前工作目录 ; pwd:打印当前目录
#!/bin/bash
# 显示当前目录
echo "当前目录: $(pwd)"# 改变到 home 目录
cd ~
echo "已切换到 Home 目录: $(pwd)"# 返回上一级目录
cd ..
echo "返回上一级目录: $(pwd)"
exit:退出脚本返回一个状态码
#!/bin/bash
echo "脚本即将退出"
exit 0 # 退出脚本并返回状态码 0(表示成功)
read:读取用户输入
#!/bin/bash
echo "请输入你的名字:"
read name
echo "你好, $name"
test - 条件测试
#!/bin/bash
# 文件存在性测试
if test -e "/etc/passwd"; thenecho "文件 /etc/passwd 存在"
elseecho "文件 /etc/passwd 不存在"
fi# 字符串测试
str="hello"
if test "$str" = "hello"; thenecho "字符串匹配"
elseecho "字符串不匹配"
fi# 数字比较
a=5
b=10
if test $a -lt $b; thenecho "$a 小于 $b"
fi
常用外部命令
即常见的Linux服务器命令,下面对于常用的做出总结
ls :列出指定目录中的文件和子目录
cat : 查看文件内容
grep:搜索文本
也可以在脚本中写
#!/bin/bash
# 在文件中查找包含 "hello" 的行
grep "hello" file.txt
awk : 文本处理
sed :流编译器
#!/bin/bash
# 替换文件中的 "hello" 为 "hi"
sed 's/hello/hi/' file.txt# 删除文件中包含 "world" 的行
sed '/world/d' file.txt
find:查找文件
#!/bin/bash
# 在当前目录下查找所有以 ".txt" 结尾的文件
find . -name "*.txt"# 查找最近 5 天内修改过的文件
find . -mtime -5
tar :压缩和解压
#!/bin/bash
# 创建一个 tar 包
tar -cvf archive.tar file1.txt file2.txt# 解压 tar 包
tar -xvf archive.tar
自定义函数
基本语法
# 方法1:使用 `function` 关键字
function my_function() {echo "Hello, World!"
}# 方法2:省略 `function` 关键字
my_function() {echo "Hello, World!"
}
# 方法1:使用 `function` 关键字
function my_function1() {echo "Hello, World!"
}# 方法2:省略 `function` 关键字
my_function2() {echo "Hello, World!"
}my_function1my_function2
函数参数
shell函数通过位置参数$1 $2等来使用参数
greet() {echo "Hello, $1! You are $2 years old."
}greet "Alice" 25 # 输出:Hello, Alice! You are 25 years old.
参数数量获取:通过 $#获取传递给函数的参数个数
count_args() {echo "Number of arguments: $#"
}count_args 1 2 3
返回值与错误处理
直接通过echo进行返回值
add() {result=$(( $1 + $2 ))echo $result
}sum=$(add 5 3)
echo "Sum is: $sum" # 输出:Sum is: 8
return返回状态码
-
$?
存储的是上一个命令或函数的退出状态
check_positive() {if [ $1 -gt 0 ]; thenreturn 0 # 返回0表示成功elsereturn 1 # 返回1表示失败fi
}check_positive 10
if [ $? -eq 0 ]; thenecho "Positive number"
elseecho "Non-positive number"
fi
错误处理
check_error() {if [ $1 -lt 0 ]; thenecho "Error: Negative number!" >&2exit 1fi
}check_error -1
区部变量和全局变量
使用局部变量
-
local
关键字限制变量在函数内部有效 - 如果没有使用
local
,变量将是全局的,函数外部也可以访问
example() {local var="I am local"echo $var
}example
echo $var
全局变量
- 函数内部不使用
local
,则变量会变成全局变量,函数外部也能访问
global_example() {global_var="I am global"
}global_example
echo $global_var
递归函数
factorial() {if [ $1 -le 1 ]; thenecho 1elseprev=$(factorial $(( $1 - 1 )))echo $(( $1 * prev ))fi
}result=$(factorial 5)
echo "Factorial of 5 is: $result"
函数调试
set -x
和set +x
允许你跟踪函数内部的执行过程
set -x # 开启调试模式,显示每行命令及其执行结果example_debug() {echo "This is a debug example"echo "Another line"
}example_debugset +x # 关闭调试模式
正则表达式
常规匹配
点号.:
a.b
将匹配任意字符(除了换行符)位于a
和b
之间的字符串
方括号
[]
(匹配字符集中的任意一个字符):例如[aeiou]
匹配任何一个元音字母(a
、e
、i
、o
、u
)
apple
banana
grape
pear
orange
umbrella
插入符号
^
(匹配行的开始):用来匹配以特定字符串开头的行
apple pie
banana split
apple tart
grape fruit
apple cider
$:匹配行结束,主要用来匹配特定字符串结尾的行
apple pie
banana tart
apple tart
grape tart
orange juice
|:示逻辑“或”操作符,匹配任意一个模式
apple
banana
carrot
grape
cucumber
orange
*:例如a*匹配零个或者多个a
+:匹配前一个字符或者多个
常用特殊字符
\:转移字符
\.
、\*
、\+
等- 用于转义字符,使它们失去特殊意义,变为字面量字符。例如,
.
通常匹配任意字符,但如果你想匹配一个字面量的点,可以使用\.
():分组和捕获
- 语法:
(abc|def)
- 说明:圆括号用于创建分组。它们可以帮助你将一部分模式组合在一起,从而作为一个整体来进行匹配
apple pie
banana split
grape fruit
apple tart
orange juice
{}:量词
- 语法:
a{n,m}
、a{n}
- 说明:大括号用于指定前一个字符出现的次数。例如,
a{2,4}
匹配2到4个a
,而a{3}
只匹配正好3个a
aa
aaa
aaaa
aaaaa
文本处理工具
cut
概述
用于从文本文件中提取字段、列或字符,可以通过指定分隔符、字段范围、字符位置等来灵活提取所需的数据
常用选项
-f
:选择字段。-d
:指定分隔符。-c
:选择字符位置。--complement
:选择除了指定字段之外的所有字段。-s
:只显示包含分隔符的行。
基本语法
cut OPTION... [FILE]...
常用选项和用法
-f
:选择字段
- 语法:
cut -f FIELD
-f
用来指定要提取的字段。字段是通过分隔符(默认是制表符)来划分的-d ','
用来指定字段的分隔符是逗号,而-f 1,3
表示提取第一列和第三列- 注意文中如果有其他注释会失效
-d
:指定分隔符
- 语法:
cut -d DELIM
- 使用
-d
选项来指定字段分隔符,默认为制表符。你可以将其设置为其他字符(如逗号、空格等)
-c
:按字符位置选择
- 语法:
cut -c N
- 使用
-c
选项根据字符位置选择字段。你可以选择一个或多个字符位置进行提取 - 提取每一行的前三个字符
--complement
:选择非指定字段
- 语法:
cut --complement
使用--complement
选项选择除指定字段之外的所有字段 - 使用
cut
提取除了第一列和第三列之外的所有列
-s
:只显示有分隔符的行
- 语法:
cut -s
- 使用
-s
选项来排除没有分隔符的行
awk
概述
基本语法
awk 'pattern { action }' input_file
pattern
:用于匹配的模式(正则表达式)。如果省略,则awk
会对每一行都执行动作action
:在模式匹配后执行的操作。如果省略,则默认打印匹配的行input_file
:要处理的输入文件。如果不指定,awk
会从标准输入读取数据
常用选项
打印整行内容
awk
会打印所有匹配行。只给出awk '{ print }'
就会打印每一行
打印指定字段
awk
将每一行默认按空格或制表符分割成字段,字段可以通过$n
访问,其中n
是字段的数字(从 1 开始)。$1
表示第一字段,$2
表示第二字段,依此类推
使用分隔符 -F
- 默认情况下,
awk
使用空格和制表符作为字段分隔符。你可以使用-F
选项指定其他分隔符
条件判断
基础运算
BEGIN END
BEGIN
和END
是特殊的块,用来在处理文本前或后执行操作。BEGIN
用于在处理前执行,END
用于在处理后执行
结合正则表达式使用
内置变量的使用
NR
:表示当前记录(行)的编号NF
:表示当前行的字段数FS
:字段分隔符,默认为空格或制表符OFS
:输出字段分隔符,默认为空
修改输出时的字段数值
相关文章:

【shell编程】函数、正则表达式、文本处理工具
函数 系统函数 常见内置命令 echo打印输出 #!/bin/bash # 输出普通文本 echo "Hello, World!"# 输出变量值 name"Alice" echo "Hello, $name"# 输出带有换行符的文本 echo -n "Hello, " # -n 选项不输出换行 echo "World!&quo…...

解决 npm xxx was blocked, reason: xx bad guy, steal env and delete files
问题复现 今天一位朋友说,vue2的老项目安装不老依赖,报错内容如下: npm install 451 Unavailable For Legal Reasons - GET https://registry.npmmirror.com/vab-count - [UNAVAILABLE_FOR_LEGAL_REASONS] vab-count was blocked, reas…...

如何进行高级红队测试:OpenAI的实践与方法
随着人工智能(AI)技术的迅猛发展,AI模型的安全性和可靠性已经成为业界关注的核心问题之一。为了确保AI系统在实际应用中的安全性,红队测试作为一种有效的安全评估方法,得到了广泛应用。近日,OpenAI发布了两…...

Java:二维数组
目录 1. 二维数组的基础格式 1.1 二维数组变量的创建 —— 3种形式 1.2 二维数组的初始化 \1 动态初始化 \2 静态初始化 2. 二维数组的大小 和 内存分配 3. 二维数组的不规则初始化 4. 遍历二维数组 4.1 for循环 编辑 4.2 for-each循环 5. 二维数组 与 方法 5.1…...

Android 天气APP(三十七)新版AS编译、更新镜像源、仓库源、修复部分BUG
上一篇:Android 天气APP(三十六)运行到本地AS、更新项目版本依赖、去掉ButterKnife 新版AS编译、更新镜像源、仓库源、修复部分BUG 前言正文一、更新镜像源① 腾讯源③ 阿里源 二、更新仓库源三、修复城市重名BUG四、地图加载问题五、源码 前…...

Xilinx IP核(3)XADC IP核
文章目录 1. XADC介绍2.输入要求3.输出4.XADC IP核使用5.传送门 1. XADC介绍 xadc在 所有的7系列器件上都有支持,通过将高质量模拟模块与可编程逻辑的灵活性相结合,可以为各种应用打造定制的模拟接口,XADC 包括双 12 位、每秒 1 兆样本 (MSP…...

计算机网络socket编程(2)_UDP网络编程实现网络字典
个人主页:C忠实粉丝 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C忠实粉丝 原创 计算机网络socket编程(2)_UDP网络编程实现网络字典 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记,欢迎大家在评论区交流讨…...

c#窗体列表框(combobox)应用——省市区列表选择实例
效果如下: designer.cs代码如下: using System.Collections.Generic;namespace 删除 {public partial class 省市区选择{private Dictionary<string, List<string>> provinceCityDictionary;private Dictionary<string,List<string&…...
Nginx 架构与设计
Nginx 是一个高性能的 HTTP 和反向代理服务器,同时也可以用作邮件代理和通用的 TCP/UDP 负载均衡器。它的架构设计以高并发、高可扩展性和高性能为目标,充分利用操作系统提供的多路复用机制和事件驱动模型。以下是 Nginx 的架构和设计特点: 1…...

python Flask指定IP和端口
from flask import Flask, request import uuidimport json import osapp Flask(__name__)app.route(/) def hello_world():return Hello, World!if __name__ __main__:app.run(host0.0.0.0, port5000)...
多线程 相关面试集锦
什么是线程? 1、线程是操作系统能够进⾏运算调度的最⼩单位,它被包含在进程之中,是进程中的实际运作单位,可以使⽤多线程对 进⾏运算提速。 ⽐如,如果⼀个线程完成⼀个任务要100毫秒,那么⽤⼗个线程完成改…...

【数据结构】—— 线索二叉树
引入 我们现在提倡节约型杜会, 一切都应该节约为本。对待我们的程序当然也不例外,能不浪费的时间或空间,都应该考虑节省。我们再观察团下图的二叉树(链式存储结构),会发现指针域并不是都充分的利用了,有许…...

uni-app 发布媒介功能(自由选择媒介类型的内容) 设计
1.首先明确需求 我想做一个可以选择媒介的内容,来进行发布媒介的功能 (媒介包含:图片、文本、视频) 2.原型设计 发布-编辑界面 通过点击下方的加号,可以自由选择添加的媒介类型 但是因为预览中无法看到视频的效果&…...

How to update the content of one column in Mysql
How to update the content of one column in Mysql by another column name? UPDATE egg.eggs_record SET sold 2024-11-21 WHERE id 3 OR id 4;UPDATE egg.eggs_record SET egg_name duck egg WHERE id 2;...

URL在线编码解码- 加菲工具
URL在线编码解码 打开网站 加菲工具 选择“URL编码解码” 输入需要编码/解码的内容,点击“编码”/“解码”按钮 编码: 解码: 复制已经编码/解码后的内容。...

Python3 爬虫 Scrapy的安装
Scrapy是基于Python的分布式爬虫框架。使用它可以非常方便地实现分布式爬虫。Scrapy高度灵活,能够实现功能的自由拓展,让爬虫可以应对各种网站情况。同时,Scrapy封装了爬虫的很多实现细节,所以可以让开发者把更多的精力放在数据的…...

QT中QString类的各种使用
大部分的QString使用可以参考:QT中QString 类的使用--获取指定字符位置、截取子字符串等_qstring 取子串-CSDN博客 补充一种QString类的分离:Qt QString切割(Split()与Mid()函数详解)_qstring split-CSDN博客 1. Trimmed和Simplified函数(去除空白) trimmed:去除了…...
linux 网络安全不完全笔记
一、安装Centos 二、Linux网络网络环境设置 a.配置linux与客户机相连通 b.配置linux上网 三、Yum详解 yum 的基本操作 a.使用 yum 安装新软件 yum install –y Software b.使用 yum 更新软件 yum update –y Software c.使用 yum 移除软件 yum remove –y Software d.使用 yum …...
uniapp将图片url转换成base64支持app和h5
uniapp将图片url转换成base64支持app和h5 imageToBase64支持app和h5, app内使用plus.io.resolveLocalFileSystemURL方法转换 h5内使用uni.request方法转换 // 图片转base64 export const imageToBase64 (path) > {// #ifdef APP-PLUSreturn new Promise((resolve, rejec…...

odoo17 档案管理之翻译2
翻译格式:#: model_terms:对象名称,arch_db:模块名.xml_id #. module: dms #: model_terms:ir.ui.view,arch_db:dms.view_dms_directory_kanban #: model_terms:ir.ui.view,arch_db:dms.view_dms_file_kanban #: model_terms:ir.ui.view,arch_db:dms.view_dms_tag_…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...

2025年能源电力系统与流体力学国际会议 (EPSFD 2025)
2025年能源电力系统与流体力学国际会议(EPSFD 2025)将于本年度在美丽的杭州盛大召开。作为全球能源、电力系统以及流体力学领域的顶级盛会,EPSFD 2025旨在为来自世界各地的科学家、工程师和研究人员提供一个展示最新研究成果、分享实践经验及…...
Oracle查询表空间大小
1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...

解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...

dify打造数据可视化图表
一、概述 在日常工作和学习中,我们经常需要和数据打交道。无论是分析报告、项目展示,还是简单的数据洞察,一个清晰直观的图表,往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server,由蚂蚁集团 AntV 团队…...
AGain DB和倍数增益的关系
我在设置一款索尼CMOS芯片时,Again增益0db变化为6DB,画面的变化只有2倍DN的增益,比如10变为20。 这与dB和线性增益的关系以及传感器处理流程有关。以下是具体原因分析: 1. dB与线性增益的换算关系 6dB对应的理论线性增益应为&…...

【分享】推荐一些办公小工具
1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由:大部分的转换软件需要收费,要么功能不齐全,而开会员又用不了几次浪费钱,借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...
【JavaSE】多线程基础学习笔记
多线程基础 -线程相关概念 程序(Program) 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序,比如我们使用QQ,就启动了一个进程,操作系统就会为该进程分配内存…...

【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...