跳至主要内容

python 之 xml

http://python101.pythonlibrary.org/chapter23_xml.html

ElementTree

创建

  1. import xml.etree.ElementTree as xml
  2.  
  3. def createXML(filename):
  4.     """
  5.    Create an example XML file
  6.    """
  7.     root = xml.Element("zAppointments")
  8.     appt = xml.Element("appointment")
  9.     root.append(appt)
  10.  
  11.     # add appointment children
  12.     begin = xml.SubElement(appt, "begin")
  13.     begin.text = "1181251680"
  14.  
  15.     uid = xml.SubElement(appt, "uid")
  16.     uid.text = "040000008200E000"
  17.  
  18.     alarmTime = xml.SubElement(appt, "alarmTime")
  19.     alarmTime.text = "1181572063"
  20.  
  21.     state = xml.SubElement(appt, "state")
  22.  
  23.     location = xml.SubElement(appt, "location")
  24.  
  25.     duration = xml.SubElement(appt, "duration")
  26.     duration.text = "1800"
  27.  
  28.     subject = xml.SubElement(appt, "subject")
  29.  
  30.     tree = xml.ElementTree(root)
  31.     with open(filename, "wb") as fh:
  32.         tree.write(fh)
  33.  
  34.  
  35. if __name__ == "__main__":
  36.     createXML("appt.xml")

解析

  1. import xml.etree.cElementTree as ET
  2.  
  3. def parseXML(xml_file):
  4.     """
  5.    Parse XML with ElementTree
  6.    """
  7.     tree = ET.ElementTree(file=xml_file)
  8.     print(tree.getroot())
  9.     root = tree.getroot()
  10.     print("tag=%s, attrib=%s" % (root.tag, root.attrib))
  11.  
  12.     for child in root:
  13.         print(child.tag, child.attrib)
  14.         if child.tag == "appointment":
  15.             for step_child in child:
  16.                 print(step_child.tag)
  17.  
  18.     # iterate over the entire tree
  19.     print("-" * 40)
  20.     print("Iterating using a tree iterator")
  21.     print("-" * 40)
  22.     iter_ = list(tree.iter())
  23.     for elem in iter_:
  24.         print(elem.tag)
  25.  
  26.     # get the information via the children!
  27.     print("-" * 40)
  28.     print("Iterating using getchildren()")
  29.     print("-" * 40)
  30.     appointments = list(root)
  31.     for appointment in appointments:
  32.         appt_children = list(appointment)
  33.         for appt_child in appt_children:
  34.             print("%s=%s" % (appt_child.tag, appt_child.text))
  35.  
  36. if __name__ == "__main__":
  37.     parseXML("appt.xml")
  38.  
  39.     state = xml.SubElement(appt, "state")
  40.  
  41.     location = xml.SubElement(appt, "location")
  42.  
  43.     duration = xml.SubElement(appt, "duration")
  44.     duration.text = "1800"
  45.  
  46.     subject = xml.SubElement(appt, "subject")
  47.  
  48.     tree = xml.ElementTree(root)
  49.     with open(filename, "wb") as fh:
  50.         tree.write(fh)
  51.  
  52.  
  53. if __name__ == "__main__":
  54.     createXML("appt.xml")


评论

此博客中的热门博文

学习地址

清华大学计算机系课程攻略 https://github.com/PKUanonym/REKCARC-TSC-UHT 浙江大学课程攻略共享计划 https://github.com/QSCTech/zju-icicles https://home.unicode.org/ 世界上的每个人都应该能够在手机和电脑上使用自己的语言。 http://codecanyon.net   初次看到这个网站,小伙伴们表示都惊呆了。原来代码也可以放在网上卖的?!! 很多coder上传了各种代码,每个代码都明码标价。看了下销售排行,有的19刀的卖了3万多份,额di神啊。可以看到代码的演示效果,真的很漂亮。代码以php、wordpress主题、Javascript、css为主,偏前台。 https://www.lintcode.com/ 算法学习网站,上去每天刷两道算法题,走遍天下都不怕。 https://www.codecademy.com/ 包含在线编程练习和课程视频 https://www.reddit.com/ 包含有趣的编程挑战题,即使不会写,也可以查看他人的解决方法。 https://ideone.com/ 在线编译器,可运行,可查看代码示例。 http://it-ebooks.info/ 大型电子图书馆,可即时免费下载书籍。 刷题 https://github.com/jackfrued/Python-100-Days https://github.com/kenwoodjw/python_interview_question 面试问题 https://github.com/kenwoodjw/python_interview_question https://www.journaldev.com/15490/python-interview-questions#python-interpreter HTTP 身份验证 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Authentication RESTful 架构详解 https://www.runoob.com/w3cnote/restful-architecture.html https://www.rosettacode.org/wiki/Rosetta_C...

MechanicalSoup

用于自动与网站交互的 Python 库。 MechanicalSoup 自动存储和发送 cookie,跟踪重定向,并且可以跟踪链接和提交表单。 它不执行 JavaScript。 https://github.com/MechanicalSoup/MechanicalSoup https://mechanicalsoup.readthedocs.io/en/stable/index.html https://realpython.com/python-web-scraping-practical-introduction/ pip show Mechanicalsoup 找到模块的安装位置 https://stackoverflow.com/questions/54352162/download-file-with-mechanicalsoup # Install dependencies # pip install requests # pip install BeautifulSoup4 # pip install MechanicalSoup # Import libraries import mechanicalsoup import urllib.request import requests from bs4 import BeautifulSoup import re # Create a browser object that can collect cookies browser = mechanicalsoup.StatefulBrowser() browser.open("https://www.ons.gov.uk/economy/grossdomesticproductgdp/timeseries/l2kq/qna") browser.download_link(link_text=".xls",file="D:/ONS_Data.xls" )

安装和卸载软件(msi\exe)

如何判断一个软件是64位的还是32位的? 情况1、 未安装--右键安装程序查看属性,兼容性,勾选兼容模式查看最低适配是vista的是64位,反之32位, 不太准确 情况2、 已安装--运行软件,64位操作系统打开任务管理器看进程后缀名,带*32就是32位,反之64位 https://www.joci.net/xxbk/126251/ FileMon 和 Regmon 不再可供下载。从Windows 2000 SP4,Windows XP SP2,Windows Server 2003 SP1和Windows Vista开始的Windows版本上,它们已被 Process Monitor 取代 https://adamtheautomator.com/procmon/ Process Monitor 是Windows的高级监视工具,它显示实时文件系统,注册表和进程/线程活动。 它结合了两个旧的Sysinternals实用程序 Filemon 和  Regmon的功能 ,并添加了广泛的增强功能列表,包括丰富的和非破坏性的过滤,全面的事件属性(例如会话ID和用户名),可靠的过程信息,带有集成符号的完整线程堆栈支持每个操作,同时记录到文件等。 它独特的强大功能将使Process Monitor成为您的系统故障排除和恶意软件搜索工具包中的核心实用程序。 https://wikileaks.org/ciav7p1/cms/page_42991626.html HKLM\Software\Microsoft\Cryptography\MachineGuid Machine GUID/Cryptography GUID---该密钥通常用作机器的唯一标识符。它也已用于将两台计算机链接在一起-在某些情况下,计算机GUID是与设备(MP3播放器等)一起传递的。 Machine GUID不是唯一 https://docs.microsoft.com/zh-cn/windows/win32/properties/props-system-identity-uniqueid?redirectedfrom=MSDN UniqueID才是唯一 注册表 是存储系统和应用程序的设置信息 打开注册表的方式很简单:cmd中输入regedit 卸载路径只有一个 已安装32位的程序,如果是系统是32位...