文档章节

流媒体编辑器(sed awk 命令使用方式)

d
 doudou___9958
发布于 2016/10/26 19:47
字数 1038
阅读 5
收藏 0

流媒体编辑器定义:

文件就是硬盘上的一段存储空间
文件名就引用的名字
文件的内容就是存储硬盘上的字节
读取文件就一个一个字节读取出来
 
为了减少尽可能少的磁盘io操作采用换行符读取
一次只读一行

1.sed命令:

        sed命令会有自己维护的内存空间
        对文件内容复制到这个内存空间进行编辑操作
        并把结果输出到屏幕上来
1.1sed也叫行编辑器
        sed [options] 'script' File
        script具有特殊意义的一些字符
        也可以通过选项进行操作、

1.2参数:

        -n:静默模式,不输出模式空间中的内容
        -r:可以使用扩展的正则表达式
        -f /path/to/sed_script_file:指定sed脚本
        -e 'script'  -e 'script' 指定多个编辑指令的
        -i:直接编辑原文件

1.3编辑命令:
        d:删除
        p:打印
        i \text:匹配到行之前
        a \text:匹配到行之后
        r /path/to/somefile:在指定位置把另外一个文件内容插入进来
        w /path/to/somefile:将符合条件的所有行保存至指定文件中
        =:显示符合条件的行的行号
        s:查找替换 /要查找的内容// 查找的内容可以使用模式,但替换的内容不行
        正则表达式:
            基本的:
                字符:
                    .
                    []
                    [^]
                次数:
                    *
                    ?
                    grep \?
                    .*
                    {m,n}
                锚定:
                    ^
                    $
                分组:
                    ()
                引用:
                    \1,\2....
 
            扩展的:
                字符:
                    .
                    []
                    [^]
                        [[:lower:]] [[:upper:]]....
                次数:
                    *
                    ?
                    +
                    {m,n}
                锚定:
                    ^
                    $
                或:
                    a|b
                分组:
                    ()
                引用:
                    \1,\2.....    
            sed '地址定界s@查找条件@替换文本@g'
            修饰符:
                g:全局替换
                i:忽略大小写

1.3常用的命令:

             sed '1,3d' /etc/passwd:删除模式空间当中的1-3行
             sed -n '1,3d' /etc/passwd:以静默模式删除模式空间当中的1-3行
             sed '1,3p'/etc/passwd:打印模式空间当中1-3行其他行继续输出,匹配到的会多输出一行
             sed '1i \hello' /etc/passwd   在第一行的前面插入hello

              sed 'i \hello' /etc/passwd   在每一行的前面插入hello
             sed '/^#/i \hello' /etc/passwd  在以#号开头的前一行插入hello
             sed '/^#/w /tmp/filetmp' /etc/passwd 在以#开头的一行后插入并保存/tmp/filetmp文件
             sed '/^#/r /tmp/112' /etc/passwd   在以#开头的一行后插入/tmp/112文件
             sed 's@^#@@g' /etc/passwd:搜索以#开头的并替换为“ ”。   注意这里删除的只是#不是删除的正行
             其中@@@这里面的内容可以现在vim当只进行测试表示意思与///一样。

2.awk命令

            报告生成工具
            对每一行的每一个字段进行操作并格式化,而后进行显示
            变量,条件判断,循环
            主要是生成美观的输出结果
 
2.1用法格式:
            awk [options] 'script' File....
            awk [options] '/pattern/{action}' File....
 
            action:默认 print
2.2模式pattern:
            地址定界:/pat1/,/pat2/
            /pattern/
            expression
            >,<,>=,<=,==,!=,~模式匹配
        BEGIN:
            每一行处理之前预处理
        END:
            每一行处理之后的处理
    awk常用四种分隔符
        输入:
            行分隔符
            字段分隔符
        输出:
            行分隔符
            字段分隔符
    awk内置变量:
        NF:字段数    
        FS:读入分隔符默认空白
        OFS:输出分隔符默认空白    
 
    -F:指定分隔符
    默认空格
    $0整行
    $1第一列
    .....
    地址定界:
        startline,endline
        1,3
        /pat1/,/pat2/,从匹配par1的行到pat2结束之间的行
        /patter/被这个匹配到行都输出

2.3常用命令:

            awk -F ":" '{print $1}' /etc/passwd:打印文件的第一列,以冒号分割的
            awk '/^#/ {print $1}' /etc/fstab:打印以#开头的第一列
            awk 'BEGIN {FS=":"} {print $1}' /etc/passwd 打印文件的第一列,以冒号分割的
            awk '{print "username:"$1,"uid:"$3}' /etc/passwd对第一列前加上username:,第三列前加上uid:
           awk '{printf "username:%s uid:%d",$1,$3}'

            awk 'BEGIN {FS=":";OFS=":"} {print $1}' /etc/passwd
            awk 'BEGIN {FS=":|#";OFS=":"} {print $1}' /etc/passwd
            awk '$3>=500 {print $1}' /etc/passwd打印uid大于500的用户名
            awk '$7~/bash$/ {print $1}' /etc/passwd
            awk '/bash$/ {print $1}' /etc/passwd
            awk '{print $NF}':打印文件的最后一列,即使每一行的最后一列不是统一

© 著作权归作者所有

d
粉丝 4
博文 44
码字总数 54396
作品 0
成都
私信 提问
linux下grep、awk和sed工具用法概览

linux下grep、awk和sed工具用法概览 在linux下,grep、awk和sed是非常强大的文本处理工具,其中grep命令主要用作文本搜索,而awk和sed命令侧重于文本的编辑等操作,另外awk本身还可以是编程语...

小陶小陶
2018/09/11
175
0
使用sed在文件中定位文本的方式

sed是实现对流的编辑。通常,我们使用sed可以实现内容的编辑后然后保存成另外的一个文件,如果正确的话,才写入到源文件。但是某些时候,我们需要直接修改文件,因为,保存文件到一个文件,然...

AlphaJay
2012/03/05
3.6K
0
shell脚本抽取文本文件中指定字符串的方法:sed+grep方法、awk+grep方法(必要时可以联合sed以及grep)、grep+cut方法

在linux中经常要对一些动态的文本文件抽取指定的字符串,比如执行ps命令后想要获取指定的运行进程(如ps自己)的PID号(同一个进程每次启动的时候pid号是随机分配的)。该怎么办呢?当然,可以...

WXXGoodJob
2018/11/08
0
0
Linux删除重复行

文本处理时,经常要删除重复行,下面是三种方法 第一,用sort+uniq,注意,单纯uniq是不行的。 sort -n test.txt | uniq 第二,用sort+awk命令,注意,单纯awk同样不行,原因同上。 sort -n ...

晨曦之光
2012/03/02
943
0
Linux删除重复行

文本处理时,经常要删除重复行,下面是三种方法 第一,用sort+uniq,注意,单纯uniq是不行的。 sort -n test.txt | uniq 第二,用sort+awk命令,注意,单纯awk同样不行,原因同上。 sort -n ...

长平狐
2013/01/06
48
0

没有更多内容

加载失败,请刷新页面

加载更多

debian10使用putty配置交换机console口

前言:Linux的推广普及,需要配合解决实际应用方能有成效! 最近强迫自己用linux进行实际工作,过程很痛苦,还好通过网络一一解决,感谢各位无私网友博客的帮助! 系统:debian10 桌面:xfc...

W_Lu
37分钟前
10
0
aelf Enterprise 0.8.0 beta有奖公测,“Bug奖金计划”重磅开启

2019年9月30日,aelf Enterprise 0.8.0 beta版正式发布。aelf Enterprise 0.8.0 beta是一个完备的区块链系统, 包含完备的区块链系统、开发套件、开发文档、以及配套的基础应用和基础服务。 ...

AELF开发者社区
38分钟前
8
0
oracle 初始化数据库脚本

create user lpf identified by 123456; create tablespace lpf_ts_cms datafile '/opt/app/oracle/product/11.2.0/lpf.dbf' size 200M; alter user lpf default tablespace lpf_ts_cms; sel......

internetafei
42分钟前
7
0
《区块链DAPP开发入门、代码实现、场景应用》笔记1——天外飞仙DAPP

Solidity编程语言解决了编写智能合约的不友好的问题,但是当合约编译并部署之后,对与这些接口的访问,对于一般的使用者来说,门槛有点高, 对普通用户来说也是非常不友好,为了使广大用户理...

柯南和由美
47分钟前
6
0
流程图制作软件推荐_流程图制作软件哪个好

流程图(Flow Chart)是一种表示算法思路的图示,通过特定图形、图表可以直观的说明某一过程。这种过程既可以是生产线上的工艺流程图,也可以标明某项任务必需的管理过程。为了便于识别,绘制...

工具分享
49分钟前
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部