Linux echo, sort, sed 等一些命令总结

linux echo, sort, sed是初学linux shell script 的一些常用的命令。基本上来说,如果能够掌握了这些命令,我们就能写出一些不错的linux脚本。以下是我遇到的以下常用的echo,sort, sed等命令的一些应用;

1.  echo -e: BW="f25\nf50\nf75\nf100\n";

如果直接echo $BW, 结果是f25\nf50\nf75\nf100\n。所以我们必须加上-e选项才能实现换行的目的,即echo -e $BW

Note:echo -e 处理特殊字符

若字符串中出现以下字符,则特别加以处理,而不会将它当成一般文字输出:

\a 发出警告声;

\b 删除前一个字符;

\c 最后不加上换行符号;

\f 换行但光标仍旧停留在原来的位置;

\n 换行且光标移至行首;

\r 光标移至行首,但不换行;

\t 插入tab;

\v 与\f相同;

\\ 插入\字符;

\nnn 插入nnn(八进制)所代表的ASCII字符;

2. sort 排序: BW=`echo -e $BW|sed ‘s/f/f /g‘|sort -ugk2|sed ‘s/ //g‘`;

sed ‘s/f/f /g‘: 人为制造一个分隔符“ ”出来

sort -u:清除重复行

-g: 按照数字大小排序: 一般来说, 假如有五个数: 1  3 11 12 21, 它会按照第一个数的大小来排,即1 11 12 21 3, 加-g 或-n 之后,就会正常排序, 即1 3 11 12 21

-k: 一般和-t一起用, -t 是分隔符,默认为空格,sort-ugk2 其实是 sort -u -t " " -k2 -g。其中-k2, 是指按照分割符后面的值得大小排序

sed ‘s/ //g‘: 删除分隔符

Note: sort [-bcfMnrtk][源文件][-o 输出文件] 
补充说明:sort可针对文本文件的内容,以行为单位来排序。

参  数:
  -b   忽略每行前面开始出的空格字符。
  -c   检查文件是否已经按照顺序排序。

-u   除去重复行

-f   排序时,忽略大小写字母。
  -M   将前面3个字母依照月份的缩写进行排序。
  -n   依照数值的大小排序。compare according to string numerical value

-g  compare according to general numerical value
  -o<输出文件>   将排序后的结果存入指定的文件。
  -r   以相反的顺序来排序。

-R random排序
  -t<分隔字符>   指定排序时所用的栏位分隔字符。
  -k  选择以哪个区间进行排序。

参考:http://www.cnblogs.com/dong008259/archive/2011/12/08/2281214.html

3. sed: cat Runlist.txt | sed ‘s/^#.*//g‘|sort -R;

假如Runlist.txt里面的内容是:

test_short/test_UL_CellID
test_short/test#_UL_DL_cfg .2
test_short/test_UL_MCS
#test_short/test_UL_RNTI in the adb list

cat Runlist.txt | sed ‘s/^#.*//g‘|sort -R: 那么这句话是把以#开头的一行删除。

test_short/test_UL_CellID
test_short/test#_UL_DL_cfg .2
test_short/test_UL_MCS

cat Runlist.txt | sed ‘s/#.*//g‘|sort -R: 那么这句话是把以#后面的内容删除。

test_short/test_UL_CellID

test_short/test_UL_MCS
test_short/test#

cat Runist.txt | sed ‘/#/d‘: 删除#出现的那一行

test_short/test_UL_CellID

test_short/test_UL_MCS

3a. 匹配数据,然后进行操作
只需要在上述的基础上加上正则匹配
sed "/匹配的模式/处理的方式" file.txt 
sed "/^root/d" file.txt 对开始有root的删除

cat Runist.txt | sed ‘/#/s/test_short/bugs/g/‘:  找到#出现的那一行,然后用bugs替换test_short

 

3b. 一个比较有趣的例子: 如何替换\n也就是把所有的行都归为一行

我们可以用tr来代替sed去做这件事情: tr "\n" "  ": 用空格把 \n换行替代

Note: sed [-nefr] [动作] 文件
参数:
-n 安静模式,在sed处理的时候,所有来自STDIN的数据都会被输出到终端,加上-n会只输出处理的哪行
-e 直接在命令列上进行sed动作编辑
-f 直接将sed的动作写在文件内
-r sed动作支持延伸的正则表达(默认只是基础正则)
-i 直接修改文件内容(慎用,尤其是用系统文件做练习的时候)非常有用,不加这个选项,只会在屏幕中print出来

动作:
a append:增加,在当前行的下一行增加
c   :取代,取代n1到n2之间的行
d delete:删除
i 插入,目前行的上一行插入
p 打印,常常与-n使用
s 取代,s/old/new/g

http://blog.csdn.net/hello_hwc/article/details/40118129

时间: 2024-10-12 18:29:18

Linux echo, sort, sed 等一些命令总结的相关文章

linux下用sed和grep命令替换目录下所有文件中的字符串

试例如下: 第三条命令是将当前目录下代码中所有的"arm-none-linux-gnueabi" 替换成 "arm-linux" sed -i 's/arm-none-linux-gnueabi-g++/arm-linux-g++\ -O2\ -I\$\(INC\)\ -I\$\(INCSYS\)\ -static/g' `grep arm-none-linux-gnueabi-g++ . -rl` sed -i 's/arm-none-linux-gnueabi-

Linux下的sed流编辑器命令详解

sed是stream editor的简称,也就是流编辑器.它一次处理一行内容,处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕.接着处理下一行,这样不断重复,直到文件末尾.文件内容并没有 改变,除非你使用重定向存储输出. 使用语法 sed命令的使用规则是这样的: sed [option] 'command' input_file -n 使用安静(silent)模式(想不通为什么不是-s

Linux三剑客之sed命令

选定行的范围:,(逗号) 删除操作:d命令 显示模式空间内容 追加(行下):a\命令 插入(行上):i\命令 退出:q命令 多点编辑:e命令 从文件读入:r命令 写入文件:w命令 替换操作:s命令 替换文本中的字符串: 全面替换标记g 保持和获取:h命令和G命令 保持和互换:h命令和x命令 sed 简介 sed 工作原理 命令格式 常用选项: 地址定界: 编辑命令: 替换标记: sed元字符集(正则表达式) 高级编辑命令: sed用法实例 作业: 作业: sed命令 sed 简介 Stream

〖Linux〗使用sed命令修改小端(little endian)存储的数据

1 #!/bin/bash - 2 #=============================================================================== 3 # 4 # FILE: hex_change.sh 5 # 6 # USAGE: ./hex_change.sh 7 # 8 # DESCRIPTION: 9 # 10 # OPTIONS: --- 11 # REQUIREMENTS: --- 12 # BUGS: --- 13 # NOTES:

Linux入门之sed命令案例

实战: 1.删除/etc/grub.conf文件中行首的空白符: sed -r '[email protected]^[[:spapce:]][email protected]@g' /etc/grub.conf 2.替换/etc/inittab文件中"id:3:initdefault:"一行中的数字为5: sed '[email protected]\(id:\)[0-9]\(:initdefault:\)@\15\[email protected]' /etc/inittab 3.

转义序列Escape Sequences及Linux echo命令多种颜色显示

翻阅了很多中文的博文,多数文章是讲echo颜色的用法,本人实在不爱死背,追本溯源,真正看看转义序列是什么? 转义字符,学习过C语言的童鞋都知道,著名的printf函数中支持一些控制字符输出,例如\t .\n等.我们通常称它们为转义字符. 一.转义序列是什么? 1.维基百科(译者怕翻译偏差大,保留原文)    In computing, ANSI escape code (or escape sequences) is the method of in-band signaling to cont

Linux 之 sed 与 find 命令结合使用

sed 与 find 命令结合使用 目的:把/root/kang目录下,所有带有*.sh结尾的文件,并且内容oldboy的字符串,替换成kang [[email protected] kang]# find /root/kang/ -type f -name "*.sh"|xargs /root/kang/nginx/abc.sh /root/kang/test.sh #查出总共有两个文件 [[email protected] kang]# find /root/kang/ -type

每个Linux用户都应该了解的命令行省时技巧

伯乐在线导读:有网友在问答网站Quora上提问:“有哪些省时小技巧,是每个Linux用户都应该知道的?” Joshua Levy 平常就在 Linux 平台工作,并且他积累了不少实用命令行技巧,他在回复中精选出一部分.对技术用户来说,这些技巧挺重要或实用,但知道的人并不多.下文略有点长,一般来 说,用户也不需要对全部内容都了解,但为了达到省时方便的目的,Joshua Levy  仍不遗余力做了校对,以保证列出的每一条都值得一读,前提是你是一位Linux重度用户. 为了获取文中提到的一个命令的更多

linux学习:sed与awk与tr用法整理

流编辑器:sedsed 's/pattern/replace_string/' file #从给定文本中的字符串利用正则表达式进行匹配并替换每一行中第一次符合样式的内容sed 's/text/replace/' file > newfile #替换每一行中第一次符合样式的内容并将替换结果重定向到新文件sed -i 's/test/replace/' file #参数-i使用替换每一行中第一次符合样式的内容结果应用于源文件sed 's/pattern/replace_string/g' file