Python将内容写入文件的方法总结。

news2024/9/22 9:29:17

       使用Python写入文件是我们coder的日常,本篇带你详细看一下python将内容写入文件的方法以及细节。主要包括write()方法、writelines() 方法、print() 函数、使用 csv 模块、使用 json 模块。

目录

 一、write()方法

二、writelines() 方法

三、print() 函数

四、使用 csv 模块

 五、使用 json 模块


 一、write()方法

        使用 write() 方法:使用 open() 函数打开文件,然后使用 write() 方法将内容写入文件。例如:

with open('example.txt', 'w') as f:
    f.write('Hello, world!')

   open() 函数是 Python 内置的用于打开文件的函数,其常用的参数及其含义如下:

  1. file: 文件名或文件路径。可以是绝对路径或相对路径。如果是相对路径,则相对于当前工作目录。如果省略了路径,就在当前工作目录中打开文件。

  2. mode: 文件打开模式。可以是以下值之一:

    • 'r': 只读模式。默认模式,如果文件不存在,会引发异常。
    • 'w': 写模式。如果文件不存在,则创建文件。如果文件已存在,则清空文件并写入新内容。
    • 'x': 独占创建模式。如果文件不存在,则创建文件。如果文件已存在,则引发异常。
    • 'a': 追加模式。如果文件不存在,则创建文件。如果文件已存在,则将新内容添加到文件末尾。
    • 'b': 二进制模式。与其他模式一起使用,例如 'rb''wb'
    • 't': 文本模式。与其他模式一起使用,例如 'rt''wt'
  3. buffering: 设置缓冲区的大小。如果省略或为0,则不进行缓冲。如果为1,则行缓冲。如果大于1,则为缓冲区大小。

  4. encoding: 用于编码和解码文件内容的编码格式。如果省略,使用默认编码。

  5. errors: 编码和解码文件内容时遇到错误时的处理方式。可以是以下值之一:

    • 'strict': 默认值,表示遇到错误时引发异常。
    • 'ignore': 忽略错误。
    • 'replace': 用 '?' 替换错误的字符。
    • 'backslashreplace': 用反斜杠转义替换错误的字符。
    • 'xmlcharrefreplace': 用 XML 实体替换错误的字符。
    • 'namereplace': 用 \N{...} 转义替换错误的字符。
  6. newline: 控制文本模式下的换行符处理方式。可以是以下值之一:

    • None: 使用默认换行符 \n
    • '': 不进行换行符转换。
    • '\n', '\r', '\r\n', '\u2028', '\u2029': 使用指定的换行符。
  7. closefd: 如果为 True,则表示将在打开文件时关闭其底层文件描述符。默认为 True

  8. opener: 用于打开文件的自定义函数或类。默认为 None

     这些参数可以以不同的组合使用,以满足对文件的不同操作需求。例如,open('example.txt', 'w') 会以写模式打开名为 example.txt 的文件,如果文件不存在,则创建一个新的空文件。 

二、writelines() 方法

    writelines() 方法将一个字符串列表写入文件。例如:

with open('example.txt', 'w') as f:
    lines = ['Hello, world!', 'Welcome to Python']
    f.writelines(lines)

      writelines() 方法是用于将字符串列表写入文件的方法。但是需要注意以下几点: 

  1. writelines() 方法只接受字符串列表作为参数。如果要写入单个字符串,请使用 write() 方法。

  2. writelines() 方法不会在字符串之间自动添加换行符,需要手动将其添加到字符串中。

  3. writelines() 方法不会在列表的最后添加空行,如果需要在最后一行添加空行,请手动添加一个包含换行符的空字符串。

  4. 在使用 writelines() 方法时,需要保证传递的参数是一个字符串列表。如果参数是一个生成器对象,需要将其转换为列表再传递。

lines = ['line 1\n', 'line 2\n', 'line 3\n']

with open('example.txt', 'w') as f:
    f.writelines(lines)

        方法的高级用法主要是将迭代器对象中的数据写入文件,而不需要将其一次性转换为列表。这种用法对于大型数据集合很有用,因为它可以逐个迭代元素,避免将所有元素存储在内存中。

def generate_lines():
    yield 'line 1\n'
    yield 'line 2\n'
    yield 'line 3\n'

with open('example.txt', 'w') as f:
    f.writelines(generate_lines())

        在上面的代码中,generate_lines() 函数返回一个迭代器对象,它逐个生成字符串。然后,将这个迭代器对象传递给 writelines() 方法,writelines() 方法将迭代器对象中的字符串逐个写入文件。

三、print() 函数

        可以使用 print() 函数向文件写入内容,需要指定 file 参数为打开的文件对象。例如:

with open('example.txt', 'w') as f:
    print('Hello, world!', file=f)

        以下是 print() 函数的常用参数及其详细介绍:

print() 函数是 Python 中用于打印输出信息到终端的内置函数。print() 函数可以接受多个参数,并将它们打印输出到终端。

以下是 print() 函数的常用参数及其详细介绍:

print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

*objects:一个或多个要打印输出的对象,可以是字符串、数字、变量等。可以接受任意数量的参数。

sep:用于分隔多个参数的字符,默认是一个空格。在打印输出多个参数时,sep 参数将作为它们之间的分隔符。

end:用于表示打印输出结束的字符,默认是一个换行符。在打印输出最后一个参数之后,end 参数将作为它们之后的字符。

file:用于指定输出的文件对象,默认是标准输出设备 sys.stdout。可以将输出重定向到文件中,以便将输出保存到文件中而不是终端。

flush:用于指定是否立即刷新缓冲区,默认为 False。如果将 flush 参数设置为 True,则输出将立即写入文件,而不是等待缓冲区满了再写入。

# 打印输出单个字符串
print("Hello World")

# 打印输出多个参数
print("Name:", "John", "Age:", 25)

# 使用自定义分隔符
print("Name:", "John", "Age:", 25, sep="-")

# 使用自定义结束符
print("Name:", "John", "Age:", 25, end=".")

# 将输出重定向到文件
with open('output.txt', 'w') as f:
    print("Hello World", file=f)

# 立即刷新缓冲区
print("Hello World", flush=True)

print(string, *args, **kwargs)

string:格式化字符串,其中包含要打印输出的信息和格式化占位符。格式化占位符用花括号 {} 包裹,并指定要填充的数据的类型、宽度、精度等信息。

*args:可选参数,包含要填充到格式化字符串中的数据。

**kwargs:可选参数,包含键值对,用于指定格式化字符串中的占位符的值。

name = "John"
age = 25

# 使用占位符输出字符串
print("Name: {}, Age: {}".format(name, age))

# 使用关键字参数输出字符串
print("Name: {n}, Age: {a}".format(n=name, a=age))

# 使用 f-string 输出字符串
print(f"Name: {name}, Age: {age}")

四、使用 csv 模块

        可以使用 csv 模块将数据写入 CSV 文件。例如:

import csv

with open('example.csv', 'w', newline='') as f:
    writer = csv.writer(f)
    writer.writerow(['Name', 'Age', 'Gender'])
    writer.writerow(['Alice', 25, 'F'])
    writer.writerow(['Bob', 30, 'M'])

 五、使用 json 模块

        可以使用 json 模块将 Python 对象写入 JSON 文件。例如:

import json

data = {
    'name': 'Alice',
    'age': 25,
    'gender': 'F'
}

with open('example.json', 'w') as f:
    json.dump(data, f)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/357517.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Java】中的各种锁

Java提供了种类丰富的锁,每种锁因其特性的不同,在适当的场景下能够展现出非常高的效率。 一、Java锁是什么?为什么要用Java锁? 在并发编程中,经常遇到多个线程访问同一个共享资源 ,这时候作为开发者必须考…

【汇编】一、环境搭建(一只 Assember 的成长史)

嗨~你好呀! 我是一名初二学生,热爱计算机,码龄两年。最近开始学习汇编,希望通过 Blog 的形式记录下自己的学习过程,也和更多人分享。 这篇文章主要讲述汇编环境的搭建过程。 话不多说~我们开始吧! 系统环…

Ubuntu下安装 ntfs-3g

目录1.FAT32、NTFS和exFAT2.ubuntu 安装 ntfs-3g2.1 直接安装2.2 源码安装1.FAT32、NTFS和exFAT U盘在格式化的时候都会有三种格式分别是FAT32、NTFS和exFAT。 FAT32格式   FAT32格式硬盘分区的最大容量为2TB,虽然U盘做不到,但是现在1xTB硬盘都有了&…

实现8086虚拟机(三)——指令解码

文章目录中间指令格式解码模块的实现编译器将汇编语句翻译成机器指令,而虚拟机做的工作正好相反,就是将机器指令解码成可以识别的中间形式,然后执行。为什么要这么做?拿 mov 指令举例,看下它的机器指令的格式&#xff…

手动创建 vue2 ssr 开发环境

本文和个人博客同步发表 更多优质文章查看个人博客 前言 手动搭建 vue ssr 一直是一些前端开发者的噩梦,因为其中牵扯到很多依赖包之间的配置以及webpack在node中的使用。就拿webpack配置来说,很多前端开发者还是喜欢用webpack-cli脚手架搭建项目。导致…

NCHW - NHWC - CHWN 排列

TensorFlow有两种数据格式NHWC和NCHW,默认的数据格式是NHWC,可以通过参数data_format指定数据格式。这个参数规定了 input Tensor 和 output Tensor 的排列方式。 1、data_format 设置为 “NHWC” 时,排列顺序为 [batch, height, width, channels] 设置为 “NCHW” 时,排…

Linux中常用命令汇总三

Linux中常用命令汇总二地址:https://blog.csdn.net/u011837804/article/details/1289972501、用户组管理类每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如Linux下的用户属…

MIPI CSI 进一步理解

CSI(Camera Serial Interface)定义了摄像头外设与主机控制器之间的接口,旨在确定摄像头与主机控制器在移动应用中的标准。 CSI关键词描述 缩写 解释 CCI Camera Control Interface(物理层组件,通常使用I2C或I3C进行通…

显示技术之器件---LED、Mini LED、Micro LED、OLED、LCD、SMD、SMT

显示技术之基础—半导体 1、LED 1.1 LED(Light Emitting Diode) 即发光二极管,是一种半导体固体发光器件,它是利用固体半导体芯片作为发光材料,当两端加上正向电压,半导体中的载流子发生复合引起光子发射而产生光。LED由含镓&a…

基于SpringBoot的卓越导师双选系统

文末获取源码 开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7/8.0 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea Maven包:Maven3.3.9 浏…

九龙证券|机构密集调研银行业!这些上市银行尤其受捧,关注两大变量

2023年开年以来,组织连续了上一年对上市银行的调研热情。 Wind数据显现,到现在,年内已有9家银行承受637家组织调研,参加调研的组织数较上一年同期添加近一成。 其间,7家被调研银行均处江浙区域。上一年以来&#xff0…

Docker 学习笔记

概述 1. 什么是 Docker? Docker 是一个应用容器平台,管理项目中用到的所有环境(MySQL、Redis…) 2. Docker 和虚拟机的区别 虚拟机是携带操作系统的,本身很小的应用程序因为携带了操作系统而变得十分笨重&#xff0…

WebRTC paced sender

文章目录4.1 pacer创建4.2 音视频数据包发送4.3 webrtc::PacketRouter4.4 Pacer 媒体数据发送控制4.5 pacer 中的码率探测paced sender通常简称为pacer,其是WebRTC RTP栈的一部分,用于平滑发送到网络上的数据流包,考虑一个帧率为60fps带宽为1…

linux高级命令之线程的注意点

线程的注意点学习目标能够说出线程的注意点1. 线程的注意点介绍线程之间执行是无序的主线程会等待所有的子线程执行结束再结束线程之间共享全局变量线程之间共享全局变量数据出现错误问题2. 线程之间执行是无序的import threading import timedeftask():time.sleep(1)print(&qu…

一句话解读《持续交付》核心能力

​DevOps 是基于持续交付的软件工程。DevOps的核心知识体系在DevOps 四书。持续交付主要是指应用软件集成交付环节,通过配置管理、构建与持续集成、测试管理、部署与发布管理、环境管理、数据管理和度量管理领域的能力建设和工程实践保证软件持续顺畅高质量的对用户…

JavaWeb9-volatile解决内存可见性和指令重排序问题

目录 1.解决内存可见性问题 2.解决指令重排序问题 3.volatile缺点 4.特使使用场景 volatile(易变的,易挥发的,不稳定的)可以解决内存可见性和指令重排序的问题。 1.解决内存可见性问题 代码在写入 volatile 修饰的变量时&am…

【Linux】自定义生成Kickstart(system-config-kickstart)

文章目录前言一、安装二、运行三、配置3.1 基本配置3.2 安装方法3.3 引导装载程序选项3.4 分区信息3.5 网络配置3.6 验证3.7 防火墙配置3.8 显示配置3.9 软件包选择3.10 预安装脚本3.11 安装后脚本3.12 保存与查看四、总结前言 本文简单介绍下system-config-kickstart的使用&a…

AMQP协议介绍

这篇文章主要介绍AMQP 0-9-1 协议,是RabbitMQ支持的协议之一,理解AQMP对于使用和理解RabbitMQ也很有帮助。 AMQP 0-9-1(高级消息队列协议)是一种消息传递协议,它使客户端应用程序能与消息中间件进行通信。消息中间件接…

Alibaba Arthas

Alibaba Arthas 基于arthas 3.4.6 Arthas是Alibaba开源的Java诊断工具 可以用来解决 查看class 的加载路径,排除ClassLoader 双向委派存在的问题 程序在线反编译,与热更新 监控到JVM的实时运行状态(线程状态,程序热点&#x…

敏感词之 DFA 算法

敏感词之 DFA 算法 常用算法 遍历匹配 将输入的词语,与词库中的敏感词逐个字符遍历,对比是否包含 优点:思路简单,易于实现(KMP 算法,Brute-Force 算法) 缺点:当词库数目非常大时…