买个5000多游戏本,选什么买房子选哪层比较好好啊

linux bash字符串处理大全
字体:[ ] 类型:转载 时间:
linux bash字符串处理大全,需要的朋友可以参考下
取得字符串的长度 代码如下:代码:%x="abcd"#方法一%expr length $x4# 方法二%echo ${#x}4# 方法三%expr "$x" : ".*"4# expr 的帮助# STRING : REGEXP&& anchored pattern match of REGEXP in STRING
代码如下:代码:%expr index& $x "b"2%expr index& $x "a"1%expr index& $x "b"2%expr index& $x "c"3%expr index& $x "d"4
得到子字符串
代码如下:代码:# 方法一# expr &string& startpos length%expr substr "$x" 1 3abc%expr substr "$x" 1 5abcd%expr substr "$x" 2 5bcd# 方法二# ${x:pos:lenght}%echo ${x:1}bcd%echo ${x:2}cd%echo ${x:0}abcd%echo ${x:0:2}ab%pos=1%len=2%echo ${x:$pos:$len}bc匹配正则表达式 代码如下:代码:# 打印匹配长度%expr match $x "."1%expr match $x "abc"3%expr match $x "bc"0
字符串的掐头去尾 代码如下:代码:%x=aabbaarealwwvvww%echo "${x%w*w}"aabbaarealwwvv%echo "${x%%w*w}"aabbaareal%echo "${x##a*a}"lwwvvww%echo "${x#a*a}"bbaarealwwvvww
其中 , # 表示掐头, 因为键盘上 # 在 $ 的左面。其中 , % 表示%,& 因为键盘上 % 在 $ 的右面。单个的表示最小匹配,双个表示最大匹配。也就是说,当匹配的有多种方案的时候,选择匹配的最大长度还是最小长度。
字符串的替换
代码如下:代码:%x=abcdabcd%echo ${x/a/b} # 只替换一个bbcdabcd%echo ${x//a/b} # 替换所有bbcdbbcd
不能使用 regexp ,只能用 * ? 的文件扩展方式。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具shell&&文件内容替换&sed用法
调用sed命令有两种形式:
sed [options] 'command'
sed [options] -f scriptfile
删除:d命令&
$ sed '2d'
example-----删除example文件的第二行。
sed '2,$d' example-----删除example文件的第二行到末尾所有行。
$ sed '$d'
example-----删除example文件的最后一行。
'/test/'d example-----删除example文件所有包含test的行。
's/要被替换的字符串/新的字符串/g'
$ sed 's/test/mytest/g'
example-----在整行范围内把test替换为mytest。
如果没有g标记,则只有每行第一个匹配的test被替换成mytest。
#!/bin/bash
's/172.30.0.122:1521:iboxpay/要替换的IP:端口:实例/g'
/home/wdk/proxool.xml
sed -i 's/"tst"/要替换的数据库用户名/g'
/home/wdk/proxool.xml
sed -i 's/"ok"/要替换的数据库密码/g'
/home/wdk/proxool.xml
/home/wdk/proxool.xml
's/被替换的内容/要替换成的内容/' file & &
& &-i 直接修改并保存
# nl /etc/passwd | sed '2,5d'
&删除2~5行
# nl /etc/passwd | sed '3,$d'
&删除3~最后一行 & &
& $代表最后一行
# nl /etc/passwd | sed '2a drink tea?'
& 在第二行之后加入“drink tea?”
/etc/passwd | sed '2i drink tea?' &
&在第二行之前加入”drink tea?“
/etc/passwd | sed '2a drink
tea?\ & 在第二行之后加入“drink tea?”并以“\”结束,回车后
& drink beer
?\ & &在“drink tea?”后加入一行
以“ \ ”结束
# &nl /etc/passwd | sed '2,5c
NO 2-5 NUMBER' & &
将第2~5行的内容替换为“NO 2-5 NUMBER”
$ sed -n 's/^test/mytest/p'
-----(-n)选项和p标志一起使用表示只打印那些发生替换的行。也就是说,如果某一行开头的test被替换成mytest,就打印它。
's/^192.168.0.1/&localhost/'
-----&符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加
localhost,变成192.168.0.1localhost。
$ sed -n 's//(love/)able//1rs/p'
-----love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。
$ sed 's#10#100#g'
-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。
选定行的范围:逗号&
$ sed -n '/test/,/check/p'
-----所有在模板test和check所确定的范围内的行都被打印。
'5,/^test/p' example-----打印从第五行开始到第一个包含以test开始的行之间的所有行。
多点编辑:e命令&
$ sed -e '1,5d' -e 's/test/check/'
example-----(-e)选项允许在同一行里执行多条命令。如例子所示,第一条命令删除1至5行,第二条命令用check替换test。命令的执
行顺序对结果有影响。如果两个命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。
--expression='s/test/check/' --expression='/love/d'
-----一个比-e更好的命令是--expression。它能给sed表达式赋值。
从文件读入:r命令&
$ sed '/test/r file'
-----file里的内容被读进来,显示在与test匹配的行后面,如果匹配多行,则file的内容将显示在所有匹配行的下面。
写入文件:w命令&
$ sed -n '/test/w
file' example
-----在example中所有包含test的行都被写入file里。
追加命令:a命令&
$ sed '/^test/a//---&this is a example'
example&-----'this is a
example'被追加到以test开头的行后面,sed要求命令a后面有一个反斜杠。
插入:i命令&
$ sed '/test/i//&
-------------------------' example
如果test被匹配,则把反斜杠后面的文本插入到匹配行的前面。
下一个:n命令&
$ sed '/test/{ s/aa/bb/; }'
example-----如果test被匹配,则移动到匹配行的下一行,替换这一行的aa,变为bb,并打印该行,然后继续。
变形:y命令&
$ sed '1,10y/abcde/ABCDE/'
example-----把1--10行内所有abcde转变为大写,注意,正则表达式元字符不能使用这个命令。
退出:q命令&
$ sed '10q' example-----打印完第10行后,退出sed。
保持和获取:h命令和G命令&
$ sed -e '/test/h' -e '$G
example-----在sed处理文件的时候,每一行都被保存在一个叫模式空间的临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将
打印在屏幕上。接着模式空间被清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命令将其复制并存入一个称为保
持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G命令取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中
的行的末尾。在这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。
保持和互换:h命令和x命令&
$ sed -e '/test/h' -e '/check/x' example
-----互换模式空间和保持缓冲区的内容。也就是把包含test与check的行互换。
Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非常挑剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行为注释行,且不能跨行。
比如,如果要打印出含有字串”1024”的行,我就可能会用:
cat filename | sed &n ‘/1024/p’
&sed /^$/d filename
& &可以删除文件中的空行。
sed /^[[:space:]]*$/d filename &
&可以删除内容为多个空格/tab组成的行。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。&&&&&&&&&&&
/html/develop/60.html
经常看到一些脚本中, 做一些简单的字符串处理/计算字符串长度,也动用管道+ awk/sed/cut等相对重量级工具:),其实大可不必, 因为bash本身就自带一些简单字符串处理功能, 这样至少可以减少重新fork一个进程来做字符串处理的开销, 也算为服务器减排co2做一些贡献吧:)
# 定义几个变量用于测试目的FILE_NAME="/usr/local/app/world.txt"TIME_NOW="`date +"%Y%m%d%H%M%S"`"
# 1. 取字符串的子串, 比如说从TIME_NOW分别取出日期和时间DATE_TODAY="${TIME_NOW:0:8}"&&& # ${var:beg_pos:sub_str_length}, beg_pos是子串的起始位置(从0开始), sub_str_length为子串长度TIME_TODAY="${TIME_NOW:8:6}"# 或者TIME_TODAY="${TIME_NOW:8}"&&&&& # sub_str_length为0表示到源字符串的结尾
# 取FILE_NAME中的文件名world.txt(不包括路径), 很多童鞋会马上想到basename, 或者一些类似于正则匹配的操作
${FILE_NAME##*/} & & & & & & & &# 相当于basename ${FILE_NAME},即删除按从左至右,匹配一直到最后一个/之间的子串
${FILE_NAME%/*} & & & & & & & & # 相当与dirname, 即删除按从右至左方向开始,匹配到第一个/之间的子串
${FILE_NAME#*/} & & & & & & & & # 从左至右, 删除第一个/及左边的子串
${FILE_NAME%%/*} & & & & & & & &# 从右至左, 删除至最后一个/及右边的子串
# 2. 字符串替换
${FILE_NAME/world.txt/hello.txt}&&& # 把第一个world.txt替换成hello.txt${FILE_NAME//a/A}&&&&&&&&&&&&&&&&&& # 把所有的a替换成A
# 3. 计算字符串长度${#FILE_NAME}&&&&&&&&&&&&&&&&&& # 计算FILE_NAME的长度
ARRAY=(abc defg hijklmn)${#ARRAY}&&&&&&&&&&&&&&&&&&&&&& # 计算这个数组的维数${#ARRAY[2]}&&&&&&&&&&&&&&&&&&& # 计算这个数组第三个元素的长度
对于字符串的处理, 暂时能想到这么一些了, 接触这些东西, 也是因为偶尔会看看操作系统的一些脚本都这样用, 感觉比较专业一些, 自己以前处理一些字符串的时候, 也会用awk/sed加上管道等等, 感觉会略显业余同时确实会在cpu开销上作出一些贡献,虽然只是些许:)
结束语:&&& 现在全球都在谈节能减排, 我们能做些什么呢? 数据显示, 目前信息和通信技术领域造成的二氧化碳排放量已占全球二氧化碳排放总量的大约2%, 在2007年,全球的电脑、打印机、手机和各种小型的IT产品共产生了8.3亿吨的碳排放量,这一数字与航空业的碳排量相当。 在写脚本的时候,如何有效使用能够更加减少cpu的负载,如何更加能提高脚本的执行速度, 请继续关注《我也要低碳》系列。
阅读(...) 评论() &温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
是金子,总会发光的,是镜子,总会反光的……
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
匹配:m/&regexp&/ (还可以简写为 /&regexp&/ ,略去 m)替换:s/&pattern&/&replacement&/转化:tr/&pattern&/&replacemnt&/这三种形式一般都和 =~ 或 !~ 搭配使用(其中 "=~" 表示相匹配,在整条语句中读作 does,"!~" 表示不匹配,在整条语句中读作 doesn't),并在左侧有待处理的标量变量。如果没有该变量和 =~ !~ 操作符,则默认为处理 $_ 变量中的内容。举例如下:$str = "I love Perl";$str =~ m/Perl/; # 表示如果在 $str 中发现 "Perl" 字符串,则返回 "1" 否则返回 "0"。$str =~ s/Perl/BASH/; # 表示将变量 $str 中的 "Perl" 字符串替换为 "BASH",如果发生此替换则返回 "1",否则返回 "0"。$str !~ tr/A-Z/a-z/; # 表示将变量 $str 中的所有大写字母转化为小写字母,如果转化发生了则返回 "0",否则返回 "1"。另外还有:foreach (@array) { s/a/b/; } # 此处每次循环将从 @array 数组中取出一个元素存放在 $_ 变量中,并对 $_ 进行替换处理。while (&FILE&) { print if (m/error/); } # 这一句稍微复杂一些,他将打印 FILE 文件中所有包含 error 字符串的行。Perl 的正则表达式中如果出现 () ,则发生匹配或替换后 () 内的模式被 Perl 解释器自动依次赋给系统 $1, $2 ...... 请看下面的例子:$string = "I love perl";$string =~ s/(love)/&$1&/; # 此时 $1 = "love",并且该替换的结果是将 $string 变为 "I &love& perl"$string = "i love perl";$string =~ s/(i)(.*)(perl)/&$3&$2&$1&/; # 这里 $1 = "i",$2 = " love ",$3 = "perl",并且替换后 $string 变为 "&perl& love &i&"替换操作 s/&pattern&/&replacement&/ 还可以在末尾加上 e 或 g 参数,他们的含义分别为:s/&pattern&/&replacement&/g 表示把待处理字符串中所有符合 &pattern& 的模式全部替换为 &replacement& 字符串,而不是只替换第一个出现的模式。s/&pattern&/&replacement&/e 表示将把 &replacemnet& 部分当作一个运算符,这个参数用的不多。比如下面的例子:$string = "i:love:perl";$string =~ s/:/*/; #此时 $string="i*love:perl";$string = "i:love:perl";$string =~ s/:/*/g; #此时 $string="i*love*perl";&$string =~ tr/*/ /; #此时 $string="i love perl";&$string = "www22cgi44";$string =~ s/(\d+)/$1*2/e; # (/d+)代表 $string 中的一个或多个数字字符,将这些数字字符执行 *2 的操作,因此最后 $string 变成了 "www44cgi88"。一个完整的例子:# Perl的字符串匹配: =~m/pattern/ ,其中m可省略# 匹配字符串变量$string 中是否存在子串 ‘regex’my $string = "regex exists!";print "string: $string\n";if ($string =~ m/regex/) {& print "match\n";} else {& print "no match\n";}#Perl的字符串替换: =~s/regex/replacement/g ,其中g指将字符串中的所有‘regex’子串全部替换# 匹配字符串变量$string 中是否存在子串 ‘regex’,并用‘relacement’替换$string =~ s/regex/replacement/g;print "string: $string\n";运行结果:string: regex exists!matchstring: replacement exists!二、正则表达式中的一些常用模式/pattern/ 结果. 匹配除换行符以外的所有字符x? 匹配 0 次或一次 x 字符串x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数.* 匹配 0 次或一次的任何字符.+ 匹配 1 次或多次的任何字符{m} 匹配刚好是 m 个 的指定字符串{m,n} 匹配在 m个 以上 n个 以下 的指定字符串{m,} 匹配 m个 以上 的指定字符串[] 匹配符合 [] 内的字符[^] 匹配不符合 [] 内的字符[0-9] 匹配所有数字字符[a-z] 匹配所有小写字母字符[^0-9] 匹配所有非数字字符[^a-z] 匹配所有非小写字母字符^ 匹配字符开头的字符$ 匹配字符结尾的字符\d 匹配一个数字的字符,和 [0-9] 语法一样\d+ 匹配多个数字字符串,和 [0-9]+ 语法一样\D 非数字,其他同 \d\D+ 非数字,其他同 \d+\w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样\w+ 和 [a-zA-Z0-9]+ 语法一样\W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样\W+ 和 [^a-zA-Z0-9]+ 语法一样\s 空格,和 [\n\t\r\f] 语法一样\s+ 和 [\n\t\r\f]+ 一样\S 非空格,和 [^\n\t\r\f] 语法一样\S+ 和 [^\n\t\r\f]+ 语法一样\b 匹配以英文字母,数字为边界的字符串\B 匹配不以英文字母,数值为边界的字符串a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串abc 匹配含有 abc 的字符串(pattern)
() 这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量或是 \1 变量,第二个 () 内所找到的字符串变成 $2 这个变量或是 \2 变量,以此类推下去。/pattern/i i 这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。\ 如果要在 pattern 模式中找寻一个特殊字符,如 "*",则要在这个字符前加上 \ 符号,这样才会让特殊字符失效下面给出一些例子: &&范例 说明/perl/ 找到含有 perl 的字符串/^perl/ 找到开头是 perl 的字符串/perl$/ 找到结尾是 perl 的字符串/c|g|i/ 找到含有 c 或 g 或 i 的字符串/cg{2,4}i/ 找到 c 后面跟着 2个到 4个 g ,再跟着 i 的字符串/cg{2,}i/ 找到 c 后面跟着 2个以上 g ,再跟着 i 的字符串/cg{2}i/ 找到 c 后面跟着 2个 g,再跟着 i 的字符串/cg*i/ 找到 c 后面跟着 0个或多个 g ,再跟着 i 的字符串,如同/cg{0,1}i//cg+i/ 找到 c 后面跟着一个以上 g,再跟着 i 的字符串,如同/cg{1,}i//cg?i/ 找到 c 后面跟着 0个或是 1个 g ,再跟着 i 的字符串,如同/cg{0,1}i//c.i/ 找到 c 后面跟着一个任意字符,再跟着 i 的字符串/c..i/ 找到 c 后面跟着二个任意字符,再跟着 i 的字符串/[cgi]/ 找到符合有这三个字符任意一个的字符串/[^cgi]/ 找到没有这三个字符中任意一个的字符串/\d/ 找寻符合数字的字符,可以使用/\d+/来表示一个或是多个数字组成的字符串/\D/ 找寻符合不是数字的字符,可以使用/\D+/来表示一个或是更多个非数字组成的字符串/\*/ 找寻符合 * 这个字符,因为 * 在常规表达式中有它的特殊意思,所以要在这个特殊符号前加上 \ 符号,这样才会让这个特殊字符失效/abc/i 找寻符合 abc 的字符串而且不考虑这些字符串的大小写&三、正则表达式的八大原则  如果在 Unix 中曾经使用过 sed、awk、grep 这些命令的话,相信对于 Perl 语言中的正则表达式(Regular Expression)不会感到陌生。Perl 语言由于有这个功能,所以对字符串的处理能力非常强。在Perl语言的程序中,经常可以看到正则表达式的运用,在 CGI 程序设计中也不例外。  正则表达式是初学 Perl 的难点所在,不过只要一旦掌握其语法,你就可以拥有几乎无限的模式匹配能力,而且 Perl 编程的大部分工作都是掌握常规表达式。下面给大家介绍几条正则表达式使用过程中的 8 大原则。  正则表达式在对付数据的战斗中可形成庞大的联盟——这常常是一场战争。我们要记住下面八条原则:· 原则1:正则表达式有三种不同形式(匹配(m/ /),替换(s/ / /eg)和转换(tr/ / /))。· 原则2:正则表达式仅对标量进行匹配( $scalar =~ m/a/; 可以工作; @array =~ m/a/ 将把@array作为标量对待,因此可能不会成功)。· 原则3:正则表达式匹配一个给定模式的最早的可能匹配。缺省时,仅匹配或替换正则表达式一次( $a = 'string string2'; $a =~ s/string/ /; 导致 $a = 'string 2')。· 原则4:正则表达式能够处理双引号所能处理的任意和全部字符( $a =~ m/$varb/ 在匹配前把varb扩展为变量;如果 $varb = 'a' $a = 'as',$a =~ s/$varb/ /; 等价于 $a =~ s/a/ /; ,执行结果使 $a = " s" )。· 原则5:正则表达式在求值过程中产生两种情况:结果状态和反向引用: $a=~ m/pattern/ 表示 $a 中是否有子串 pattern 出现,$a =~ s/(word1)(word2)/$2$1/ 则“调换”这两个单词。· 原则6:正则表达式的核心能力在于通配符和多重匹配运算符以及它们如何操作。$a =~ m/\w+/ 匹配一个或多个单词字符;$a =~ m/\d/" 匹配零个或多个数字。· 原则7:如果欲匹配不止一个字符集合,Perl使用 "|" 来增加灵活性。如果输入 m/(cat|dog)/ 则相当于“匹配字符串 cat 或者 dog。· 原则8:Perl用 (?..) 语法给正则表达式提供扩展功能。(这一点请同学们课后看相关资料)想要学习所有这些原则?我建议大家先从简单的开始,并且不断的尝试和实验。实际上如果学会了 $a =~ m/ERROR/ 是在 $a 中查找子串ERROR,那么你就已经比在 C 这样的低层语言中得到了更大的处理能力。& &参考资料:
阅读(17632)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_',
blogTitle:'Perl的字符串匹配与替换',
blogAbstract:'一、Perl的字符串匹配与替换匹配:m/&regexp&/ (还可以简写为 /&regexp&/ ,略去 m)替换:s/&pattern&/&replacement&/转化:tr/&pattern&/&replacemnt&/这三种形式一般都和 =~ 或 !~ 搭配使用(其中 \"=~\" 表示相匹配,在整条语句中读作 does,\"!~\" 表示不匹配,在整条语句中读作 doesn\'t),并在左侧有待处理的标量变量。如果没有该变量和 =~ !~ 操作符,则默认为处理 $_ 变量中的内容。举例如下:',
blogTag:'',
blogUrl:'blog/static/',
isPublished:1,
istop:false,
modifyTime:0,
publishTime:6,
permalink:'blog/static/',
commentCount:0,
mainCommentCount:0,
recommendCount:0,
bsrk:-100,
publisherId:0,
recomBlogHome:false,
currentRecomBlog:false,
attachmentsFileIds:[],
groupInfo:{},
friendstatus:'none',
followstatus:'unFollow',
pubSucc:'',
visitorProvince:'',
visitorCity:'',
visitorNewUser:false,
postAddInfo:{},
mset:'000',
remindgoodnightblog:false,
isBlackVisitor:false,
isShowYodaoAd:false,
hostIntro:'是金子,总会发光的,是镜子,总会反光的……',
hmcon:'1',
selfRecomBlogCount:'0',
lofter_single:''
{list a as x}
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}

我要回帖

更多关于 两梯五户选哪户比较好 的文章

 

随机推荐