• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

关于python:第10天-12天搞定Python文件操作

python 搞代码 3年前 (2022-02-20) 36次浏览 已收录 0个评论
文章目录[隐藏]

在开发零碎的过程中,常常会用到XML存储和传输数据,XML是一种用于标记电子文件使其具备结构性的标记语言,在博客中常常会见到。

JSON是一种轻量级的数据交换格局,常被用在后端和前端的数据交互上,如你用Python提供后端WebService数据接口,App在调用这个接口时,收到的数据就是JSON文件。

txt是最常见的一种文件格式 ,次要存文本信息,即为文字信息,当初的操作系统大多应用记事本等程序保留,大多数软件能够查看,如记事本,浏览器等。

10.1 XML文件

XML指可扩大标记语言(eXtensible Markup Language)。由成对标签如<book></book>或闭环标签<book/>组成,最内部标签称为根节点。在根节点外面,能够蕴含很多子节点,子节点有本人的属性和文本。如下样例:book为根节点,name有本人的属性name,author的文本值为老陈,price为闭环标签。

<book>
<name name="书名">12天搞定Python</name>
<author>老陈</author>
<price price="0.00元" />
</book>

在自带的规范库中,Python提供了大量能够用于解决XML语言的包和工具,经我和共事测试、比拟,发现ElementTree模块是最好用的,所有我举荐你也用它来解决XML文件。

1. 创立XML

XML文件,从创立节点(book)开始,之后创立外面的子节点,并对子节点进行属性和内容增加。

import xml.etree.ElementTree as ET

# 创立根节点
book = ET.Element("book")
# 创立子节点,并增加属性和数据
title = ET.SubElement(book, "name")
title.attrib = {"name": "书名"}
title.text = "12天搞定Python"
# 创立子节点,并增加数据
author = ET.SubElement(book, "author")
author.text = "老陈"
price = ET.SubElement(book, "price")
# 创立子节点,并增加数据
price.attrib = {"price": "0.00元"}
# 创立tree对象,写文件
tree = ET.ElementTree(book)
tree.write("book.xml", encoding="UTF-8")

输入后果(book.xml文件)

<book>
<name name="书名">12天搞定Python</name>
<author>老陈</author>
<price price="0.00元" />
</book>

2. 批改XML

批改book.xml文件,新增创立日期,批改name的属性名为arr,价格调整为0.01元。

import xml.etree.ElementTree as ET


tree = ET.parse("book.xml")  # 读取待批改文件
book = tree.getroot()
# 创立新节点并增加为root的子节点
createDate = ET.Element("createDate")
createDate.attrib = {"name": "创立日期"}
createDate.text = "2020-10-01"
book.append(createDate)
# 批改书名的属性
name = book.find("name")
name.attrib = {"name": "arr"}
# 批改价格
price = book.find("price")
price.text = "0.01元"
# 写回原文件
tree.write("book.xml", encoding="UTF-8")

输入后果(book.xml文件)

<book>
<name name="arr">12天搞定Python</name>
<author>老陈</author>
<price price="0.00元">0.01元</price>
<createDate name="创立日期">2020-10-01</createDate>
</book>

3. 删除XML节点

删节点,先找到,再用remove()办法进行删除。

import xml.etree.ElementTree as ET

tree = ET.parse("book.xml")  # 读取待批改文件
book = tree.getroot()
for price in book.findall('price'):
    book.remove(price)

tree.write('book.xml', encoding="UTF-8")

输入后果(book.xml文件)

<book>
<name name="arr">12天搞定Python</name>
<author>老陈</author>
<createDate name="创立日期">2020-10-01</createDate>
</book>
  1. 读取XML

循环读取节点内容,输入不为None的节点。

import xml.etree.ElementTree as ET

tree = ET.parse("book.xml")  # 读取待批改文件
book = tree.getroot()
for node in book.iter():
    if node.text is not None:
        print(node.tag, ":", node.text) 

好了,无关XML文件的内容,老陈讲完了,如果感觉对你有所帮忙,心愿老铁能转发点赞,让更多的人看到这篇文章。你的转发和点赞,就是对老陈持续创作和分享最大的激励。

10.2 JSON文件

JSON文件数据由一系列键值对组成并用逗号隔开和咱们学过的字典可进行化相互转换。Python 中能够应用json模块对JSON 数据进行编解码。

1. 创立JSON文件

json.dumps()对字符串数据进行编码, json.dump()对文件数据进行编码。

import json

# 字典转换为JSON对象
book = {
    'name': "12天搞定Python",
    'author': '老陈',
    'price': 0.00
}

# 生成json格局
json_str = json.dumps(book, ensure_ascii=False)
# 写入 JSON 数据
with open('book.json', 'w') as f:
    json.dump(json_str, f)

输入后果(book.json文件内容)

"{"name": "12天搞定Python", "author": "老陈", "price": 0.0}"

2. 读取JSON文件

json.loads()对字符串数据进行解码, json.load() 对JSON文件进行解码。
……

我切实拷贝不动了,12天搞定Python,今天就完结了,接下来,我将公布《16天搞定Python数据分析和爬虫》,须要的敌人,能够去看一看。

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:关于python:第10天-12天搞定Python文件操作

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址