免费注册 查看新帖 |

Chinaunix

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

如何获取文件中的字符 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-15 16:55 |只看该作者 |倒序浏览
例如,文件的每一行开始都有这么一段<requestID>1000000039329</requestID>
我想获取<requestID>和</requestID>之间的那串数字,用哪个命令比较好?
每行的数字是不同的,但都有<requestID>和</requestID>
3Q!!!

[ 本帖最后由 coolminghao 于 2008-7-15 16:56 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-07-15 17:00 |只看该作者
head -1 urfile|sed 's/[^0-9]//g'

论坛徽章:
0
3 [报告]
发表于 2008-07-15 17:04 |只看该作者
grep -oP "(?<=<requestID>)[^<]*" file
or
sed -n 's#<requestID>\(.*\)</requestID>#\1#p' file

论坛徽章:
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
4 [报告]
发表于 2008-07-15 17:09 |只看该作者
  1. head -1 urfile | cut -d"<" -f2 | cut -d">" -f2
复制代码

论坛徽章:
0
5 [报告]
发表于 2008-07-15 17:23 |只看该作者
看LZ的情况,3楼比2楼的严谨,但是如果数字只出现在<requestID>和</requestID>中间的话用2楼的就足够了。

论坛徽章:
0
6 [报告]
发表于 2008-07-15 17:35 |只看该作者
sed -r -e 's/<[\/]requestID>//' -e 's/<requestID>//' test.txt
能不能一次把这两个都匹配了。
sed -r 's/<?requestID>//' test.txt
这个不行。

论坛徽章:
0
7 [报告]
发表于 2008-07-15 17:44 |只看该作者
sed -r 's,</?requestID>,,g' test.txt
/?表示/出现一次或0次。

论坛徽章:
0
8 [报告]
发表于 2008-07-15 17:49 |只看该作者
sed -r 's/<\/?requestID>//g' test.txt
还要这样写。

也可以用,这样:
sed -r 's,</?requestID>,,g' test.txt
学习了。

论坛徽章:
0
9 [报告]
发表于 2008-07-15 17:53 |只看该作者
问题还是十三问中的命令问题

论坛徽章:
0
10 [报告]
发表于 2008-07-15 18:45 |只看该作者
[root@localhost tmp]# echo "<requestID>1000000039329</requestID>"|awk -F '[<>]' '{print $3}'
1000000039329
[root@localhost tmp]#
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP