免费注册 查看新帖 |

Chinaunix

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

[文本处理] 怎么提取xml里的内容 [复制链接]

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

xml里内容为:

<urlset>
<url>
<loc>url1.html</loc>
<lastmod>2014-11-21</lastmod>
</url>
<url>
<url>
<loc>url2.html</loc>
<lastmod>2014-11-21</lastmod>
</url>
</urlset>

请问怎么提取,让结果为:

url1.html,2014-11-21
url2.html,2014-11-22

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
2 [报告]
发表于 2014-11-26 15:34 |只看该作者
  1. [root@localhost ~]# sed -n '/<loc>/{N;s/<[^>]*>//g;s/\n/,/p}' i
  2. url1.html,2014-11-21
  3. url2.html,2014-11-21
  4. [root@localhost ~]#
复制代码

论坛徽章:
0
3 [报告]
发表于 2014-11-26 15:37 |只看该作者
回复 2# yestreenstars


    谢谢大神,另外,大神请进为啥我这样不对呀?

   sed -n 's/.*>\(.*\)<\/loc>.*lastmod>\(.*\)<\/lastmod>/\1,\2/p' file

论坛徽章:
0
4 [报告]
发表于 2014-11-26 15:46 |只看该作者
  1. awk -F'[<>]' '/<lastmod>/{print a,$3}{a=$3;OFS=","}'
复制代码

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
5 [报告]
发表于 2014-11-26 15:50 |只看该作者
这种问题用python的xml模块就比较爽了。

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
6 [报告]
发表于 2014-11-26 15:50 |只看该作者
回复 3# wadeheat2

sed是一行一行处理的~
   

论坛徽章:
0
7 [报告]
发表于 2014-11-26 15:54 |只看该作者
回复 5# expert1


    是的,但是我还是喜欢shell的速度

论坛徽章:
3
天秤座
日期:2014-10-29 11:37:572015元宵节徽章
日期:2015-03-06 15:50:39NBA常规赛纪念章
日期:2015-05-04 22:32:03
8 [报告]
发表于 2014-11-26 16:09 |只看该作者

  1. import os
  2. import re
  3. a=[]
  4. f=open("d:\\11.txt","r")
  5. for i in f:
  6.    s1=re.findall(r'(?<=\<loc\>).*(?=\</loc\>)',i)
  7.    a+=s1
  8.    s2=re.findall(r'(?<=\<lastmod\>).*(?=\</lastmod\>)',i)
  9.    a+=s2
  10. for i in range(0,int(len(a)),2):
  11.     print(a[i]+","+a[i+1])
  12. f.close()
复制代码

论坛徽章:
9
2015亚冠之大阪钢巴
日期:2015-06-04 11:47:30丑牛
日期:2015-01-22 15:49:26巳蛇
日期:2015-01-22 10:11:18巨蟹座
日期:2014-11-20 10:55:03天蝎座
日期:2014-11-16 22:10:26处女座
日期:2014-11-16 11:01:10申猴
日期:2014-09-19 11:12:37双鱼座
日期:2014-07-25 10:09:54程序设计版块每日发帖之星
日期:2015-08-24 06:20:00
9 [报告]
发表于 2014-11-26 16:13 |只看该作者
wadeheat2
  1. awk -F'[<>]' '/<loc>/{printf $3",";getline;print $3}' urfile
复制代码

论坛徽章:
0
10 [报告]
发表于 2014-11-26 16:13 |只看该作者
本帖最后由 wadeheat2 于 2014-11-26 16:14 编辑

回复 8# tomer


    py代码好,O(∩_∩)O谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP