利用python实现xml与数据库读取转换的方法

发表于 5年以前  | 总阅读数:804 次

前言

xml课的第三第四个作业都是用java编程来实现xml dom的一些转换, 因为自己没怎么学过java,因此和老师说了下想用python来实现第三第四个作业,下面就直接贴代码了

xml文档


    <?xml version="1.0" encoding="UTF-8"?>
    <?xml-stylesheet type="text/xsl" href="1.xslt" rel="external nofollow" ?>
    <!DOCTYPE sys_info [
     <!ELEMENT sys_info (info+)>
     <!ELEMENT info (sysDescr,sysUpTime,sysContact,sysName)>
     <!ELEMENT sysDescr (#PCDATA)>
     <!ELEMENT sysUpTime (#PCDATA)>
     <!ELEMENT sysContact (#PCDATA)>
     <!ELEMENT sysName (#PCDATA)>
     <!ATTLIST info ip CDATA #REQUIRED>
    ]>

    <sys_info xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:noNamespaceSchemaLocation="1.xsd">
     <info ip="192.168.1.1">
      <sysDescr>X86-Windows2000</sysDescr>
      <sysUpTime>9 hours 42 minutes</sysUpTime>
      <sysContact>zhangsan</sysContact>
      <sysName>computerZhang</sysName>

     </info>
     <info ip="192.168.1.3">
      <sysDescr>router</sysDescr>
      <sysUpTime>24 hours</sysUpTime>
      <sysContact>ruijie</sysContact>
      <sysName>Router2</sysName>
     </info>
     <info ip="192.168.2.1">
      <sysDescr>router</sysDescr>
      <sysUpTime>89 hours</sysUpTime>
      <sysContact>Cisco</sysContact>
      <sysName>Router3</sysName>
     </info>
    </sys_info>

解析xml文档用的是python自带的xml库ElementTree, 读取mysql可以安装MySQLdb模块


    apt-get install python-MySQLdb

程序运行如下


    root@lj /h/s/x/3# python 21.py -h
    usage: 21.py [-h] status

    positional arguments:
     status  0clar,1read,2insert

读取xml保存到数据库


    root@lj /h/s/x/3# python 21.py 2
    插入语句: insert into info values ('192.168.1.1','X86-Windows2000','9 hours 42 minutes','zhangsan','computerZhang')
    插入语句: insert into info values ('192.168.1.3','router','24 hours','ruijie','Router2')
    插入语句: insert into info values ('192.168.2.1','router','89 hours','Cisco','Router3')
    insert success!!!

读取数据库保存到xml文档


    root@lj /h/s/x/3# python 21.py 1
    +-------------+-----------------+--------------------+------------+---------------+
    | IP地址 | sysDescr.0 | sysUpTime.0  | sysContact | sysName.0 |
    +-------------+-----------------+--------------------+------------+---------------+
    | 192.168.1.1 | X86-Windows2000 | 9 hours 42 minutes | zhangsan | computerZhang |
    | 192.168.1.3 |  router  |  24 hours  | ruijie | Router2 |
    | 192.168.2.1 |  router  |  89 hours  | Cisco | Router3 |
    +-------------+-----------------+--------------------+------------+---------------+
    write into sys.xml...

建立数据库的sql文件:


    -- MySQL dump 10.16 Distrib 10.1.21-MariaDB, for debian-linux-gnu (x86_64)
    --
    -- Host: localhost Database: localhost
    -- ------------------------------------------------------
    -- Server version 10.1.21-MariaDB-5

    /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
    /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
    /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
    /*!40101 SET NAMES utf8mb4 */;
    /*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
    /*!40103 SET TIME_ZONE='+00:00' */;
    /*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
    /*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
    /*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
    /*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

    --
    -- Table structure for table `info`
    --

    DROP TABLE IF EXISTS `info`;
    /*!40101 SET @saved_cs_client  = @@character_set_client */;
    /*!40101 SET character_set_client = utf8 */;
    CREATE TABLE `info` (
     `ip` char(15) NOT NULL,
     `sysDescr` varchar(20) DEFAULT NULL,
     `sysUpTime` varchar(40) DEFAULT NULL,
     `sysContract` varchar(20) DEFAULT NULL,
     `sysName` varchar(20) DEFAULT NULL,
     PRIMARY KEY (`ip`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
    /*!40101 SET character_set_client = @saved_cs_client */;

    --
    -- Dumping data for table `info`
    --

    LOCK TABLES `info` WRITE;
    /*!40000 ALTER TABLE `info` DISABLE KEYS */;
    INSERT INTO `info` VALUES ('192.168.1.1','X86-Windows2000','9 hours 42 minutes','zhangsan','computerZhang'),('192.168.1.3','router','24 hours','ruijie','Router2'),('192.168.2.1','router','89 hours','Cisco','Router3');
    /*!40000 ALTER TABLE `info` ENABLE KEYS */;
    UNLOCK TABLES;
    /*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

    /*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
    /*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
    /*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
    /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
    /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
    /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
    /*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

    -- Dump completed on 2017-03-23 15:36:31

下面是主要代码


    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    # @Date : 2017-03-23 14:47:39
    # @Author : 江sir (2461805286@qq.com)
    # @Link : http://www.blogsir.com.cn
    # @Version : $1.1

    import sys
    import xml.etree.ElementTree as ET
    import MySQLdb
    import argparse
    from prettytable import PrettyTable 

    '''
    一个xml作业,自己用python实现了从xml读取到数据库,和从数据库读取到xml的功能
    '''

    def buildNewsXmlFile(data):


     root = ET.Element('sys_info')#创建sys_info根元素
     # print help(ET)
     info = ET.SubElement(root, "info",attrib={'ip':'%s'%data[0][0]})#创建四个二级元素
     sysDescr = ET.SubElement(info,"sysDescr")
     sysUpTime = ET.SubElement(info,"sysUpTime")
     sysContact = ET.SubElement(info,"sysContact")
     sysName = ET.SubElement(info,"sysName")
     sysDescr.text = data[0][1]
     sysUpTime.text = data[0][2]
     sysContact.text = data[0][3]
     sysName.text = data[0][4]

     info = ET.SubElement(root, "info",attrib={'ip':'%s'%data[1][0]})
     sysDescr = ET.SubElement(info,"sysDescr")
     sysUpTime = ET.SubElement(info,"sysUpTime")
     sysContact = ET.SubElement(info,"sysContact")
     sysName = ET.SubElement(info,"sysName")
     sysDescr.text = data[1][1]
     sysUpTime.text = data[1][2]
     sysContact.text = data[1][3]
     sysName.text = data[1][4]

     info = ET.SubElement(root, "info",attrib={'ip':'%s'%data[2][0]})
     sysDescr = ET.SubElement(info,"sysDescr")
     sysUpTime = ET.SubElement(info,"sysUpTime")
     sysContact = ET.SubElement(info,"sysContact")
     sysName = ET.SubElement(info,"sysName")
     sysDescr.text = data[2][1]
     sysUpTime.text = data[2][2]
     sysContact.text = data[2][3]
     sysName.text = data[2][4]

     print 'write into sys.xml...'
     tree = ET.ElementTree(root)
     tree.write("sys.xml")


    def xml_parser():
     data = {}
     data_list = []
     tree = ET.parse('21.xml')
     root = tree.getroot()# 获取根元素
     for info in root.findall('info'): #查找所有info元素
      for child in info: #对每个info元素遍历属性和子节点
       data ['ip']= info.attrib['ip']
       data[child.tag] = child.text

      # print data.values()
      data_list.append(data.values())


     # print data_list
     return data_list



    def get_Mysql():
     conn = MySQLdb.connect('localhost','root','root','sys_info2',charset='utf8')
     cursor = conn.cursor()
     cursor.execute('select * from info');
     result = cursor.fetchall()
     if not result:
      print 'please insert the database first'
      sys.exit()


     x = PrettyTable(['IP地址','sysDescr.0','sysUpTime.0','sysContact','sysName.0'])
     for i in result:
      x.add_row(i)
     print x

     # print result
     return result

    def set_Mysql(data):
     conn = MySQLdb.connect('localhost','root','root','sys_info2',charset='utf8')
     cursor = conn.cursor()
     for i in data:
      # print tuple(i)
      sysName,ip,sysUpTime,sysDescr,sysContact = tuple(i)
      sql = "insert into info values ('%s','%s','%s','%s','%s')"%(ip,sysDescr,sysUpTime,sysContact,sysName)
      print '插入语句:',sql
      try:
       cursor.execute(sql)
      except:
       print 'please clear the database'
       sys.exit()
     print 'insert success!!!'
     conn.commit()
     conn.close()


    def clear_Mysql():
     conn = MySQLdb.connect('localhost','root','root','sys_info2',charset='utf8')
     cursor = conn.cursor()
     cursor.execute('delete from info')
     conn.commit()
     conn.close()


    def main():
     parser = argparse.ArgumentParser()
     parser.add_argument('status',type=int,help="0clar,1read,2insert")
     arg = parser.parse_args()
     # print arg
     status = arg.status
     if status == 1:
      data = get_Mysql()
      buildNewsXmlFile(data)
     elif status == 2:
      data = xml_parser()
      set_Mysql(data)
     elif status == 0:
      clear_Mysql()
     else:
      print 'usage %s [0|1|2]'%sys.argv[0]

    if __name__ == '__main__':
     main()

第四个作业是web编程,用python的flask框架即可快速实现一个xml文档的显示,文件过多,就不贴了

总结

以上就是这文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

 相关推荐

刘强东夫妇:“移民美国”传言被驳斥

京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。

发布于:1年以前  |  808次阅读  |  详细内容 »

博主曝三大运营商,将集体采购百万台华为Mate60系列

日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。

发布于:1年以前  |  770次阅读  |  详细内容 »

ASML CEO警告:出口管制不是可行做法,不要“逼迫中国大陆创新”

据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。

发布于:1年以前  |  756次阅读  |  详细内容 »

抖音中长视频App青桃更名抖音精选,字节再发力对抗B站

今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。

发布于:1年以前  |  648次阅读  |  详细内容 »

威马CDO:中国每百户家庭仅17户有车

日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。

发布于:1年以前  |  589次阅读  |  详细内容 »

研究发现维生素 C 等抗氧化剂会刺激癌症生长和转移

近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。

发布于:1年以前  |  449次阅读  |  详细内容 »

苹果据称正引入3D打印技术,用以生产智能手表的钢质底盘

据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。

发布于:1年以前  |  446次阅读  |  详细内容 »

千万级抖音网红秀才账号被封禁

9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...

发布于:1年以前  |  445次阅读  |  详细内容 »

亚马逊股东起诉公司和贝索斯,称其在购买卫星发射服务时忽视了 SpaceX

9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。

发布于:1年以前  |  444次阅读  |  详细内容 »

苹果上线AppsbyApple网站,以推广自家应用程序

据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。

发布于:1年以前  |  442次阅读  |  详细内容 »

特斯拉美国降价引发投资者不满:“这是短期麻醉剂”

特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。

发布于:1年以前  |  441次阅读  |  详细内容 »

光刻机巨头阿斯麦:拿到许可,继续对华出口

据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。

发布于:1年以前  |  437次阅读  |  详细内容 »

马斯克与库克首次隔空合作:为苹果提供卫星服务

近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。

发布于:1年以前  |  430次阅读  |  详细内容 »

𝕏(推特)调整隐私政策,可拿用户发布的信息训练 AI 模型

据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。

发布于:1年以前  |  428次阅读  |  详细内容 »

荣耀CEO谈华为手机回归:替老同事们高兴,对行业也是好事

9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI操控无人机能力超越人类冠军

《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI生成的蘑菇科普书存在可致命错误

近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。

发布于:1年以前  |  420次阅读  |  详细内容 »

社交媒体平台𝕏计划收集用户生物识别数据与工作教育经历

社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”

发布于:1年以前  |  411次阅读  |  详细内容 »

国产扫地机器人热销欧洲,国产割草机器人抢占欧洲草坪

2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。

发布于:1年以前  |  406次阅读  |  详细内容 »

罗永浩吐槽iPhone15和14不会有区别,除了序列号变了

罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。

发布于:1年以前  |  398次阅读  |  详细内容 »
 相关文章
Android插件化方案 5年以前  |  237229次阅读
vscode超好用的代码书签插件Bookmarks 2年以前  |  8063次阅读
 目录