两个bash函数创建一个数据库

echo " $1,$2"> database

grep "^$1," database| sed -e "s/^$1", //" | tail -n 1

echo " $1,$2"> database


  1. echo: echo 是一个常用的命令行工具,用于将文本输出到终端或者重定向到文件中。

  2. $1 和 $2: 这是 shell 脚本中的位置参数。当你在执行脚本时提供了参数,例如 ./script.sh apple banana,那么 $1 将是 "apple",而 $2 将是 "banana"。在这个命令中,echo "$1,$2" 将输出第一个和第二个参数,并在它们之间用逗号分隔。

  3. > database: 这是重定向操作符。它将命令的输出(在这种情况下,是 $1,$2 的值)重定向到一个名为 database 的文件中。如果 database 文件不存在,则创建它;如果存在,则会覆盖其中的内容。

因此,当你执行这个命令时,它将把 $1 和 $2 的值,以逗号分隔的形式,写入或覆盖名为 database 的文件中。例如,如果你运行 ./script.sh apple banana,那么 database 文件中将会有内容 apple,banana

grep "^$1," database| sed -e "s/^$1", //" | tail -n 1


  1. grep "^$1," database:

    • grep 是一个用于在文件中搜索文本模式的工具。

    • ^$1, 是一个正则表达式。^ 表示匹配行的开始,$1 是脚本的第一个参数,后跟一个逗号。

    • database 是要搜索的文件名。

    • 所以这个命令的意思是从 database 文件中查找以第一个脚本参数开始的行。

  2. sed -e "s/^$1", //:

    • sed 是一个流编辑器,用于处理和转换文本。

    • -e 选项用于指定编辑命令。

    • s/^$1", // 是一个替换命令。它的目的是替换文本中以第一个脚本参数开始的部分,并将其替换为空(即删除它)。

    • 因此,这个命令会删除每行开始于 $1," 的内容。

  3. tail -n 1:

    • tail 是一个用于显示文件的末尾内容的命令。

    • -n 1 选项表示只显示最后一行。

综上所述,这个整个命令的工作流程如下:

  1. 从 database 文件中搜索以脚本的第一个参数开头的行。

  2. 使用 sed 命令删除这些行中以脚本的第一个参数和逗号开始的部分。

  3. 最后,使用 tail 命令只显示经过 sed 处理后的内容中的最后一行。

这样,你将得到一个经过处理的文本,其中以 $1 开头的部分被删除,并且只返回最后一行结果。

相关推荐
o(╥﹏╥)3 分钟前
linux(ubuntu )卡死怎么强制重启
linux·数据库·ubuntu·系统安全
是小崔啊5 分钟前
开源轮子 - EasyExcel01(核心api)
java·开发语言·开源·excel·阿里巴巴
tianmu_sama11 分钟前
[Effective C++]条款38-39 复合和private继承
开发语言·c++
黄公子学安全14 分钟前
Java的基础概念(一)
java·开发语言·python
liwulin050614 分钟前
【JAVA】Tesseract-OCR截图屏幕指定区域识别0.4.2
java·开发语言·ocr
阿里嘎多学长17 分钟前
docker怎么部署高斯数据库
运维·数据库·docker·容器
jackiendsc19 分钟前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
Yuan_o_19 分钟前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
Oneforlove_twoforjob23 分钟前
【Java基础面试题027】Java的StringBuilder是怎么实现的?
java·开发语言
Sunyanhui124 分钟前
牛客网 SQL36查找后排序
数据库·sql·mysql