利用python实现xml与数据库读取转换的方法
作者:daisy 发布时间:2024-01-23 06:27:51
标签:python,xml,数据库
前言
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文档的显示,文件过多,就不贴了
来源:http://www.blogsir.com.cn/safe/354.html


猜你喜欢
- 上次我们已经搞定了逻辑层的单元测试,这次我们来康康接口层的单元测试。接口层主要负责的就是请求的处理,最常见的就是 HTTP 请求的处理。但针
- 依赖库flask安装,使用豆瓣源加速。pip install flask -i https://pypi.douban.com/simple
- 链接的 target 属性怎么用 JS 来控制? 在HTML 4.0 Strict和XHTML 1.0 STRICT里不允许在<a&g
- 现在网页的设计都讲究整体统一风格,无论是网页的文字、图像,还是浏览器的滚动条都要求颜色和风
- 本文为大家分享了卸载oracle11g的详细教程,供大家参考,具体内容如下准备工作:关闭防火墙,关闭杀毒软件1、win+R 输入servic
- 目录1、发送get请求2、发送post请求3、发送https请求4、文件上传5、文件下载6、timeout超时7、鉴权7.1、auth参数鉴
- 本文实例为大家分享了Python实现图片格式转换的具体代码,供大家参考,具体内容如下碰上这样一个情景:我从网络上下载了一张表情包图片,存放在
- 一、为 SQL 启用远程连接 1. 单击“开始”,依次指向“程序”、“Microsoft SQL Server 2005”和“配置工具”,然
- 本文实例讲述了Laravel使用PHPQRCODE实现生成带有LOGO的二维码图片功能。分享给大家供大家参考,具体如下:/*** 利用php
- 引言 上一篇介绍完了观察者模式的原理,本篇想就此再介绍一个小应用,虽然我也就玩了一下午,是当时看observer正好找到的,以及还有Djan
- 一、ts文件的由来ts文件,ts即"Transport Stream"的缩写,特点就是要求从视频流的任一片段开始都是可以
- 先看效果图 GY-85.py:#!/usr/bin/python3# -*- coding: utf-8 -*-import cursesf
- 有时候需要罗列下U盘等移动设备或一个程序下面的目录结构的需求。基于这样的需求个人整理了一个使用Python的小工具,期望对有这方面需求的朋友
- 一、name_scopewith tf.name_scope(name):name_scope: 为了更好地管理变量的命名空间而提出的。比如
- 同时在线访问量继续增大 对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机 或者时不时的服务器卡一下 这个问题曾经困扰了我半个多月My
- 使用Access数据库生成申报数据与读入数据的实例方法:示例:Sub Mwrite()On Error GoTo thiserrDim rs
- 项目需要,做一个和今日头条一样的导航栏,可以横行滚动,幸好再weui里面看到了类似的例子地址:https://weui.shanliwawa
- html5带给我们的不仅仅是更多语义丰富的标签,还有更多更牛逼的特性,比如“离线存储”。 对于台式电脑来说,或者它并没有带来什么惊喜,但是对
- 操作系统:Win7IDE:PyCharm4.5.3Django:1.10.1报错代码:request.session['key
- 前做PPT要用到折线图,嫌弃EXCEL自带的看上去不好看,就用python写了一个画折线图的程序。import matplotlib.pyp