Python中自带了XML的模块,但是性能不太好,相比之下,LXML增加了很多实用的功能。

lxml中主要有两部分,

1) etree,主要可以用来解析XML字符串,

  内部有两个对象,etree._ElementTree和etree._Element

 etree.Element对象中包含的属性和方法:

属性:1)tag,返回该节点的名称

      print 'root.tag'    输出tag

   2)text,设置该节点的文本

      root.text = 'hello world'  输出<root>hello world</root>

   3)tail,在标签后边追加文本:

      root.tail = 'hym'   输出<root>hello world</root>hym

方法:1)Element(string),创建一个Element对象:

      root = etree.Element('root')    返回一个XML的节点,名称root

      root = etree.Element('root', interesting='totally')  返回一个root节点,属性interesting = 'totally'

   2) set(name,value),为已有的节点,添加属性,

      root.set('hello', 'huhu')    增加一个属性hello = 'huhu'

     3) get(string),返回属性值

      root.get('intersting')   返回‘totally’

    4) keys(),返回所有的属性名

      root.keys()   返回interesting,hello

    5) items(),返回字典,其中包含所有的属性,及其 value

      for name,value in sorted(root.items())    返回两对属性

    6) 为该节点,添加子节点,

      child1 = etree.SubElement(root, 'child')

    7) 为该节点,删除子节点,

      root.remove(child1)

    8) getparent(),拿到父节点

      child1.getparent().tag   返回root

etree允许,节点内部的子节点,认为是一个list,

  print "len(root)"   返回root节点及其子节点的个数;

  root.index(child2)    返回child2的索引值

  child = root[0]   返回child1,允许索引访问

  for  child in root:   允许遍历

    ...

  root.insert(0, etree.Element('child0'))    允许插入

  root.append(etree.Element('child4'))    允许append

etree._Element对象是一颗xml的树,内部包含很多element的对象,

  1)root.getroottree(),返回一个节点对应的树,root表示当前节点的tag,返回的是Tree类型的对象

  2)getroot(),返回根节点,返回的是Element类型的对象

  3)etree.ELementTree(root),从一个节点构建一颗tree,该节点,也就是根节点,

etree,Element和Tree类型的对象,都支持xpath的方法:

  foo.xpath('//root')[0].tag

2) html,主要用来解析html,

  etree.html(HTML)来解析html,并得到Element对象,也可以调用xpath来分析xml

xpath,可以实现节点和属性的快速查找:

  xpath('//div[@attr = value]/text()')   返回该div节点,满足attr属性要求的,节点的文本

  xpath('//div[@attr]/@attr')  返回该div节点,含有attr属性,的值

  

  

python中的lxml模块的更多相关文章

  1. 【Day3】5.Python中的lxml模块

    import lxml.etree as le with open('edu.html','r',encoding='utf-8') as f: html = f.read() html_x = le ...

  2. Python中的random模块,来自于Capricorn的实验室

    Python中的random模块用于生成随机数.下面介绍一下random模块中最常用的几个函数. random.random random.random()用于生成一个0到1的随机符点数: 0 < ...

  3. Python中的logging模块

    http://python.jobbole.com/86887/ 最近修改了项目里的logging相关功能,用到了python标准库里的logging模块,在此做一些记录.主要是从官方文档和stack ...

  4. Python中的random模块

    Python中的random模块用于生成随机数.下面介绍一下random模块中最常用的几个函数. random.random random.random()用于生成一个0到1的随机符点数: 0 < ...

  5. 浅析Python中的struct模块

    最近在学习python网络编程这一块,在写简单的socket通信代码时,遇到了struct这个模块的使用,当时不太清楚这到底有和作用,后来查阅了相关资料大概了解了,在这里做一下简单的总结. 了解c语言 ...

  6. python中的StringIO模块

    python中的StringIO模块 标签:python StringIO 此模块主要用于在内存缓冲区中读写数据.模块是用类编写的,只有一个StringIO类,所以它的可用方法都在类中.此类中的大部分 ...

  7. python中的select模块

    介绍: Python中的select模块专注于I/O多路复用,提供了select  poll  epoll三个方法(其中后两个在Linux中可用,windows仅支持select),另外也提供了kqu ...

  8. Python中的re模块--正则表达式

    Python中的re模块--正则表达式 使用match从字符串开头匹配 以匹配国内手机号为例,通常手机号为11位,以1开头.大概是这样13509094747,(这个号码是我随便写的,请不要拨打),我们 ...

  9. python中的shutil模块

    目录 python中的shutil模块 目录和文件操作 归档操作 python中的shutil模块 shutil模块对文件和文件集合提供了许多高级操作,特别是提供了支持文件复制和删除的函数. 目录和文 ...

随机推荐

  1. 2016年蓝桥杯省赛A组c++第4题(算法填空)

    /* 排序在各种场合经常被用到. 快速排序是十分常用的高效率的算法. 其思想是:先选一个“标尺”, 用它把整个队列过一遍筛子, 以保证:其左边的元素都不大于它,其右边的元素都不小于它. 这样,排序问题 ...

  2. [skill][graphviz] 到底用什么画图: graphviz/inkscape/yed

    官方教程文档:http://www.graphviz.org/pdf/dotguide.pdf 一:在文档里抄一个简单的例子 /home/tong/Src/copyright/onescorpion/ ...

  3. todo: 改变字体的动画

    todo: 截取指定区域的图片, 改变字体的动画

  4. 内部排序->其它->地址排序(地址重排算法)

    文字描述 当每个记录所占空间较多,即每个记录存放的除关键字外的附加信息太大时,移动记录的时间耗费太大.此时,就可以像表插入排序.链式基数排序,以修改指针代替移动记录.但是有的排序方法,如快速排序和堆排 ...

  5. Android抓包方法 之Fiddler代理

    1.抓包原理 Fiddler是类似代理服务器的形式工作,它能够记录所有你的电脑和互联网之间的http(S)通讯,可以查看.修改所有的“进出”的数据.使用代理地址:127.0.0.1, 默认端口:888 ...

  6. selenium+iframe 如何定位元素(实战)

    场景: 在同一界面,需定位iframe里面的元素, 就需要切换至Iframe块,然后定位元素,验证完成后,再切换出来. 如果不切换至iframe ,会发现不管采取什么定位,都会报元素不存在.

  7. es6 学习二 Generator

    安装babel的拓展包(Polyfill) ,对Generator的转义 这是一个补完babel支持es6的拓展包,配置步骤为3个: 打开命令行键入 npm install --save-dev ba ...

  8. ES中TF-IDF算法

    概念 TF-IDF(term frequency–inverse document frequency)是一种用于资讯检索与资讯探勘的常用加权技术.TF-IDF是一种统计方法,用以评估一字词对于一个文 ...

  9. 27-1-LTDC-DMA2D—液晶显示简介

    1.显示器简介 (1).显示器属于计算机的 I/O 设备,即输入输出设备.它是一种将特定电子信息输出到屏幕上再反射到人眼的显示工具. (2).液晶是一种介于固体和液体之间的特殊物质,它是一种有机化合物 ...

  10. laravel项目出现Non-static method Redis::hGet() cannot be called statically的解决方法

    早上ytkah在配置laravel项目中出现Non-static method Redis::hGet() cannot be called statically错误提示,很显然这是redis出问题了 ...