【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_…...
MySQL报错注入实战:从错误信息读取到文件写入
1. 这不是“SQL注入教程”,而是一次真实渗透测试中的边界突破实践很多人看到“基于报错的SQL注入”第一反应是:老掉牙的技术,现在还有用?我去年在给一家本地政务系统做授权渗透时,就遇到了一个看似完全无感的登录接口—…...
超新星遗迹光学辐射特征的主控因素:环境密度与磁场影响的统计诊断
1. 项目概述:当超新星遗迹的“指纹”遇上统计学的“放大镜”在宇宙这个宏大的实验室里,超新星遗迹(Supernova Remnant, SNR)扮演着能量“搅拌器”和物质“回收站”的双重角色。一颗大质量恒星走到生命尽头,…...
外观专利和实用新型
外观设计专利与实用新型专利:技术创新的法律双翼 谨以此文,献给每一位在产品创新与外观设计之间寻求法律护城河的工程师、架构师与技术决策者。外观设计专利与实用新型专利,如同一对孪生兄弟——一个守护“美学表达”,一个护卫“实用改进”;一个关乎“看起来怎样”,一个关…...
微生物代谢建模与计算机视觉特征匹配技术解析
1. 微生物代谢建模中的协同设计1.1 工业生物技术中的代谢网络基础微生物代谢网络是细胞内酶催化化学反应的综合体系,不同物种间存在显著差异。在工业生物技术领域,这些网络能将废物流等原料转化为高附加值产品。以丁酸梭菌(Clostridium butyr…...
【2024最严合规落地清单】:金融/医疗/政务三大强监管行业AI Agent设计红线与审计通关模板
更多请点击: https://intelliparadigm.com 第一章:AI Agent设计行业应用 AI Agent正从实验室原型快速演进为可部署、可编排、可审计的企业级智能体系统,其核心价值在于将大语言模型能力封装为具备目标导向、工具调用、记忆管理与自主决策能力…...
技术人的持续学习:保持竞争力的完整指南
技术人的持续学习:保持竞争力的完整指南 引言 在快速发展的技术领域,持续学习是保持竞争力的关键。技术更新的速度越来越快,新的编程语言、框架和工具不断涌现。作为一名技术人,只有不断学习,才能跟上技术发展的步伐&a…...
云原生监控体系建设:打造全方位的可观测性平台
云原生监控体系建设:打造全方位的可观测性平台 引言 在云原生时代,监控是保障系统稳定运行的关键。一个完善的监控体系可以帮助我们及时发现问题、定位问题、解决问题。 今天就来分享一下云原生监控体系的建设经验。 监控体系概述 可观测性三支柱 监控体…...
自制靶机--Believe
Believe设计思路 靶机名称: Believe 作者:Gropers 靶机ID:661 难度: baby 靶机下载地址: https://ova-believe.oss-cn-beijing.aliyuncs.com/Believe.ova 靶机收集地址: https://maze-sec.com 靶机IP: 192.168.1.150 攻击机IP: 192.168.1.195(Kali Linu…...
Keil C51中RTX51 Tiny任务列表显示异常的解决方案
1. 问题现象与背景解析在Keil C51开发环境中使用RTX51 Tiny实时操作系统时,开发者经常会遇到一个典型问题:在Vision调试器的RTX-Tiny Tasklist窗口中,任务列表显示为空,没有任何任务状态信息。这种现象通常发生在项目已正确创建任…...
还不会通义千问向量嵌入?LangChain + DashScopeEmbeddings 全实战:原理、调用、相似度计算、RAG 落地一站式精通
文章标签:#LangChain #DashScope #通义千问 #Embedding #向量检索 #RAG 📝 本章学习目标 本章聚焦阿里云通义千问 DashScopeEmbeddings LangChain 向量嵌入实战,帮助读者从零到一掌握:DashScope 向量模型原理、LangChain 集成方…...
