前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux进价命令

Linux进价命令

作者头像
呼延十
发布2019-06-26 17:20:06
4170
发布2019-06-26 17:20:06
举报
文章被收录于专栏:呼延呼延

1. sed

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。

sed [OPTION] 'address Command ' file,...

其中, address用于指定所要操作的行,Command用于指定操作的命令.

OPTION
  • -n:静默模式,不显示模式空间中的内容
  • -i:直接修改原文件(谨慎使用)
  • -e SCRIPT -e SCRIPT:可以指定同时指定多个脚本
  • -f /PATH/TP/SED_SCRIPT:从文本中加载脚本
  • -r:使用扩展正则表达式
address

指定要操作的位置.

起始行,结束行.

function:
  • a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行).
  • c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行.
  • d :删除,因为是删除啊,所以 d 后面通常不接任何东西;
  • i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行).
  • p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行.
  • s :取代,可以直接进行取代的工作.通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g.

示例

代码语言:javascript
复制
# 将文件中,三位以上数字,并且后面有逗号的字符串替换为空.例如`2345,`
 sed 's/[0-9][0-9][0-9]\+,//g' k.txt > k6.txt
# 输出文件的第10000行到20000行到其他文件
 sed 10000,20000p ha.txt > result.txt

unip

对文件进行去重

示例

代码语言:javascript
复制
# 对1.txt排序,去重,在排序之后输出到1_tmp.txt
cat 1.txt | sort | uniq | sort > 1_tmp.txt

1.txt的内容为:

代码语言:javascript
复制
1
2
4
3
2

处理之后为:

代码语言:javascript
复制
1
2
3
4

sort

对文件排序

示例

代码语言:javascript
复制
# 对1.txt排序
cat 1.txt | sort

1.txt内容为:

代码语言:javascript
复制
1
3
2
2

排序后为:

代码语言:javascript
复制
1
2
2
3

comm

comm命令可以用于两个文件之间的比较,它有一些选项可以用来调整输出,以便执行交集、求差、以及差集操作。

参数:

代码语言:javascript
复制
-1:不显示在第一个文件出现的内容;
-2:不显示在第二个文件中出现的内容;
-3:不显示同时在两个文件中都出现的内容。

示例:

代码语言:javascript
复制
# 求交集(在两个文件中都出现)
comm -12 1.txt 2.txt
# 求差集(在第一个文件中有第二个文件没有)
comm -23 1.txt 2.txt
# 求差(两个文件同时有的不显示)
comm -3 1.txt 2.txt

实际的一个使用场景

其实这本来是mysql的工作,我需要将第一个表的主键在第二个表中的数据过滤掉.之后统计一下有多少条.

像我这种老实人,肯定就使用in语句了,结果,,,,好特么慢啊.

后来在大佬的提示下用上面几个命令完成了.

将两个表的主键都导出成文件,然后comm一下子就完事了,速度杠杠的!

参考链接

https://blog.csdn.net/tianmohust/article/details/6997924

完。

ChangeLog

2019-01-11 完成

以上皆为个人所思所得,如有错误欢迎评论区指正。

欢迎转载,烦请署名并保留原文链接。

联系邮箱:huyanshi2580@gmail.com

更多学习笔记见个人博客——>呼延十

var gitment = new Gitment({ id: 'Linux进价命令', // 可选。默认为 location.href owner: 'hublanker', repo: 'blog', oauth: { client_id: '2297651c181f632a31db', client_secret: 'a62f60d8da404586acc965a2ba6a6da9f053703b', }, }) gitment.render('container')



本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. sed
    • OPTION
      • address
        • function:
          • 示例
          • unip
            • 示例
            • sort
              • 示例
                • ChangeLog
            • comm
            • 实际的一个使用场景
            • 参考链接
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档