免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3566 | 回复: 4

增加点人气:字符串一次替换2部分 [复制链接]

论坛徽章:
0
发表于 2019-08-27 16:37 |显示全部楼层
本帖最后由 legs 于 2019-08-27 16:40 编辑

字符如下:
  1. 1a1b2c2-3d3
复制代码
"-"之前的字符里的数字替换为8,"-"之后的所有数字替换为9,结果应如下:
  1. 8a8b8c8-9d9
复制代码


会几种其它方法,没想出来直接一句替换怎么做的(不使用分组法,假设不知道哪个位置是数字)。

论坛徽章:
18
发表于 2019-08-27 17:10 |显示全部楼层

论坛徽章:
0
发表于 2019-10-15 10:56 |显示全部楼层
  1. perl -e '$s="1a2-3c22"; $a=0; $f=sub{if($_[0] eq "-"){$a=1; return "-";}elsif($a){return 9;}else{return 8;}}; $s=~s/(\d|\-)/$f->($1)/eg; print $s'
复制代码

论坛徽章:
0
发表于 2019-10-15 10:56 |显示全部楼层
  1. perl -e '$s="1a2-3c22"; $a=0; $f=sub{if($_[0] eq "-"){$a=1; return "-";}elsif($a){return 9;}else{return 8;}}; $s=~s/(\d|\-)/$f->($1)/eg; print $s'
复制代码

论坛徽章:
0
发表于 2019-10-16 10:53 |显示全部楼层
回复 4# orangetouch

谢谢,这也是种思路,不过搞得复杂了,我还是直接两个替换简单点:s///g;s///g
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

PostgreSQL中国大会,早鸟票抢购!

PostgreSQL中国大会,早鸟票抢购!
2019年11月29~11月30日,由 PostgreSQL中文社区与ITPUB联合主办的第九届《PostgreSQL 中国技术大会》将在北京隆重召开。PostgreSQL 作为功能最强的的开源关系型数据库之一,得到了越来越多企业的推广和运用,也越来越受到广大技术爱好者的欢迎和重视。这将是 PostgreSQL 的又一次交流盛会。




----------------------------------------

点击报名>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP