百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python 文件读写(txt、json、xml、ini)

liuian 2025-04-05 20:10 21 浏览

在进行接口自动化测试时,我们经常需要处理各种格式的文件。熟练掌握对这些文件的读写能力对于提升测试效率至关重要。今天我们就来一起学习如何用Python来操作常见的文件类型,包括文本文件(.txt)、JSON文件(.json)、Excel文件(.xlsx)、XML文件(.xml)以及配置文件(.ini)。我们将通过具体的代码示例来了解如何进行读写操作,并特别关注文件的追加和覆盖模式。


文本文件(.txt)

1. 追加模式写入文本文件

# 追加模式写入
with open('example.txt', 'a') as file:
    file.write('\nHello, world!')
print("追加模式写入成功")

2. 覆盖模式写入文本文件

# 覆盖模式写入
with open('example.txt', 'w') as file:
    file.write('Hello, world!')
print("覆盖模式写入成功")

3. 读取文本文件

# 读取文件
with open('example.txt', 'r') as file:
    content = file.read()
print("文本文件内容:")
print(content)


JSON文件

4. 追加模式写入JSON文件

# 追加模式写入
data = {'name': 'John', 'age': 30}
with open('data.json', 'a') as file:
    # 需要先写入一个方括号开始
    if file.tell() == 0:
        file.write('[')
    import json
    json.dump(data, file)
    if file.tell() != 0:
        file.write(',\n')
print("追加模式写入成功")

5. 覆盖模式写入JSON文件

# 覆盖模式写入
data = {'name': 'John', 'age': 30}
with open('data.json', 'w') as file:
    json.dump(data, file)
print("覆盖模式写入成功")

6. 读取JSON文件

# 读取文件
with open('data.json', 'r') as file:
    data = json.load(file)
print("JSON文件内容:")
print(data)


Excel文件

7. 写入Excel文件

# 写入Excel文件
import pandas as pd
data = {'Name': ['Alice', 'Bob'], 'Age': [25, 30]}
df = pd.DataFrame(data)
df.to_excel('example.xlsx', index=False)
print("写入Excel文件成功")

8. 读取Excel文件

# 读取Excel文件
df = pd.read_excel('example.xlsx')
print("Excel文件内容:")
print(df)


XML文件

9. 追加模式写入XML文件

# 追加模式写入
from xml.etree.ElementTree import Element, SubElement, ElementTree
root = Element('root')
child = SubElement(root, 'item')
child.text = 'Sample Text'
# 检查文件是否为空
try:
    with open('example.xml', 'r') as file:
        pass
except IOError:
    # 如果文件不存在,则创建一个新的XML文件
    ElementTree(root).write('example.xml')
else:
    # 否则追加到现有的XML文件
    tree = ElementTree(file='example.xml')
    root = tree.getroot()
    new_child = SubElement(root, 'item')
    new_child.text = 'Another Text'
    tree.write('example.xml')
print("追加模式写入成功")

10. 读取XML文件

# 读取XML文件
tree = ElementTree(file='example.xml')
root = tree.getroot()
print("XML文件内容:")
for child in root:
    print(f'{child.tag}: {child.text}')


ini文件

11. 追加模式写入配置文件

# 追加模式写入
import configparser
config = configparser.ConfigParser()
config['DEFAULT'] = {'ServerAliveInterval': '45', 'Compression': 'yes', 'CompressionLevel': '9'}
with open('example.ini', 'a') as configfile:
    config.write(configfile)
print("追加模式写入成功")

12. 覆盖模式写入配置文件

# 覆盖模式写入
config = configparser.ConfigParser()
config['DEFAULT'] = {'ServerAliveInterval': '45', 'Compression': 'yes', 'CompressionLevel': '9'}
with open('example.ini', 'w') as configfile:
    config.write(configfile)
print("覆盖模式写入成功")

13. 读取配置文件

# 读取配置文件
config = configparser.ConfigParser()
config.read('example.ini')
print("配置文件内容:")
print(config['DEFAULT']['Compression'])


相关推荐

x-cmd install | jellex - 用 Python 语法在终端里玩转 JSON 数据!

还在为命令行下处理JSON数据烦恼吗?jellex来了!它是一款基于终端的交互式JSON和JSONLines数据处理工具,让你用熟悉的Python语法,轻松过滤、转换和探索JSO...

一篇长文带你在Python里玩转Json数据

Json简介Json(JavaScriptObjectNotation)很多网站都会用到Json格式来进行数据的传输和交换,就像上篇我提到的网易云音乐接口,它们返回的数据都是Json格式的。这因为...

Python JSON 魔法手册:数据转换的终极艺术

对话实录小白:(崩溃)我从API拿到了JSON数据,怎么变成Python对象?专家:(掏出魔法书)用json模块,轻松实现数据转换!JSON基础三连击1.字符串Python对...

Python JSON 详解教程(python json())

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式(lightweightdatainterchangeformat)常用于Web应用、配置文件(co...

Python 数据的 JSON 格式序列化及反序列化

在Python中,将数据转换为JSON格式非常简单,可以使用内置的json模块。json模块提供了json.dumps()和json.dump()方法,用于将Python对象...

如何使Python类可JSON序列化(python json 类)

技术背景在Python开发中,JSON(JavaScriptObjectNotation)是一种常用的数据交换格式。然而,Python的json模块默认只能序列化一些基本数据类型,如字典、列表、字...

详细介绍一下Python如何对JSON格式数据进行处理?

在Python中对于JSON数据的处理是在日常开发中的常见需求之一。通常情况下,对JSON数据的处理主要涉及到如下的的几个步骤对于JSON数据的解析操作对于JSON数据的处理操作对于JSON数据的格式...

Python 字典l转换成 JSON(python转化字典)

本文需要5分钟。如果对您有用可以点赞评论关注.Python字典到JSONJSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它基于ECMAScrip...

打造熟悉的VS界面风格(vs界面设计美化)

用惯了老机子的VS界面,换新机子时,各种不适应。现在重新打造老款样式:1)下载VisualStudio2013ColorThemeEditorhttps://marketplace.vis...

办公小技巧:全部亮相 让Excel单元格完全显示文本

平时我们在使用Excel制作表格的时候,经常会遇到由于文本内容较多,导致这些内容无法在一个单元格中完全显示。常规的方法是将单元格设置为“自动换行”,但是这样会影响整个文件的美观。下例是某小区的入住登记...

WinForms 中的 CheckBox 控件使用指南

在WinForms中,CheckBox控件是一个允许用户选择或取消选择的单选按钮。它通常用于表示布尔值(真/假)或允许多选的情况。以下是如何使用CheckBox控件的一些基本信息和示例代码。创建...

图片转文字--四种OCR工具的安装和使用

本文仅测试简单的安装和使用,下一步应该是测试不同数据集下的检测准确率和检测效率,敬请期待。作者的系统环境是:笔记本:ThindPadP520OS:win11显卡:QuadroP520一、EasyO...

C# 给Word每一页设置不同图片水印

Word中设置水印时,可加载图片设置为水印效果,但通常添加水印效果时,会对所有页面都设置成统一效果,如果需要对每一页或者某个页面设置不同的水印效果,则可以参考本文中的方法。下面,将以C#代码为例,对W...

集成的面向对象控件Xtreme Controls正式发布v17.0.0

CodejockXtremeControls为Windows图形用户软件工程师提供众多的有关MFC的控件产品,该产品是通过完全测试并专门为图形用户设计的一款专业控件。它是一款集成了面向对象的控件被...

Win10 Build 10061老问题修复新问题来

|责编:刘菲菲【中关村在线软件资讯】4月23日消息:微软今天正式推送了Windows10Build10061预览版这个版本除了正常的功能更新和调整外,还修复了多个bug。其中一部分对于开发者开...