免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2678 | 回复: 6
打印 上一主题 下一主题

使用最简洁的方法实现以下字符串操作 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-18 17:15 |只看该作者 |倒序浏览
本帖最后由 ryh19860922 于 2011-07-18 22:29 编辑

[原创]
使用尽可能简洁的方法实现以下字符串操作
欢迎补充!


(1)将字符串中每一个字符赋值给数组
str="abcd"       ---> arr[0]=a; arr[1]=b; arr[2]=c; arr[3]=d
  1. [ryh@localhost]$  arr=(`echo  "abcd" | sed 's/./& /g'`)
复制代码



(2) 字符串内部排序
str="acdb"      ---> "abcd"
  1. [ryh@localhost]$ echo "acdb"|awk '{split($0,a,""); n=asort(a,b); for(i=1;i<=n;i++) printf "%s",b[i]}'
复制代码



(3) 字符串反向输出
str="abcd"
output:
dcba
  1. [ryh@localhost]$ echo "abcd" | rev
  2. [ryh@localhost]$ echo "abcd" | sed '/\n/!G;s/\(.\)\(.*\n\)/&\2\1/;//D;s/.//'
复制代码




(4) 字符串垂直输出
str="abcd"
output:
a
b
c
d
  1. [ryh@localhost]$ echo "abcd" | fold  -w1
  2. [ryh@localhost]$ echo "acda" | awk  '{FS="";$0=$0;OFS="\n";$1=$1}1'
复制代码



(5)判断字符串中是否有重复字符  
str1="abca"      ---> yes 或 1
str2="abcd"      ---> no 或 0
  1. [ryh@localhost]$ echo "abca" | fold  -w1| awk 'BEGIN{F=0}(n[$0]++){F=1}END{print F}'
复制代码



论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
2 [报告]
发表于 2011-07-18 21:32 |只看该作者
建议把代码放到code标签里面,以免丢失字符。

论坛徽章:
0
3 [报告]
发表于 2011-07-18 22:31 |只看该作者
建议把代码放到code标签里面,以免丢失字符。
Shell_HAT 发表于 2011-07-18 21:32

多谢提醒, 已修改!

论坛徽章:
0
4 [报告]
发表于 2011-07-19 00:24 |只看该作者
都是强人啊,学习下

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
5 [报告]
发表于 2011-07-19 01:14 |只看该作者
本帖最后由 yinyuemi 于 2011-07-19 01:37 编辑

回复 1# ryh19860922


    学习学习,
   一些补充,请指正,呵呵
  1. echo "abcd" |awk 'NF+=0' FS= OFS=' '
  2. a b c d

  3. echo "acdb"|fold -s1 |sort |tr -d '\n'
  4. abcd

  5. echo "abcd" |sed 's/^/\n/;:a;s/\(\n.*\)\(.\)/\2\1/;ta;s/\n//'
  6. dcba

  7. echo "acda" | sed -r 's/(.)(.+)/\1\n\2/;P;D'
  8. a
  9. c
  10. d
  11. a

  12. [ $(echo "abcd" |sed -nr '/(.)(.*)\1/s/.*/1/p') ] && echo yes || echo no
  13. no
  14. [ $(echo "abca" |sed -nr '/(.)(.*)\1/s/.*/1/p') ] && echo yes || echo no
  15. yes
复制代码

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
6 [报告]
发表于 2011-07-19 06:44 |只看该作者
(5)判断字符串中是否有重复字符  

echo "$str"|sed '/\(.\).*\1/{s/.*/yes/;b}; s/.*/no/'

论坛徽章:
0
7 [报告]
发表于 2011-07-19 09:12 |只看该作者
回复 5# yinyuemi
果然是sed高手, 我个人也是比较喜欢sed!

(1) 好像去掉 OFS=' ' 也行, 解释下FS的作用吧
echo "abcd" | awk 'NF+=0' FS=

(2) fold应该是-w选项吧, 或者把s去掉
哈哈, 我开始也这样做的, 不过使用了四个外部命令,
就改用awk内部排序函数了
echo "acdb"|fold -w1 |sort |tr -d '\n'
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP