两个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 开头的部分被删除,并且只返回最后一行结果。

相关推荐
Envyᥫᩣ8 分钟前
C#语言:从入门到精通
开发语言·c#
齐 飞16 分钟前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
云空17 分钟前
《Python 与 SQLite:强大的数据库组合》
数据库·python·sqlite
暮毅21 分钟前
10.Node.js连接MongoDb
数据库·mongodb·node.js
wowocpp25 分钟前
ubuntu 22.04 server 格式化 磁盘 为 ext4 并 自动挂载 LTS
服务器·数据库·ubuntu
童先生29 分钟前
Go 项目中实现类似 Java Shiro 的权限控制中间件?
开发语言·go
lulu_gh_yu31 分钟前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
成富1 小时前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
songqq271 小时前
SQL题:使用hive查询各类型专利top 10申请人,以及对应的专利申请数
数据库·sql
计算机学长felix1 小时前
基于SpringBoot的“校园交友网站”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·毕业设计·交友