Python文件处理

news2025/1/10 20:56:30

文章目录

    • 1️⃣基本语法
    • 2️⃣读取文件
      • ⚜️读取整个文件read()
      • ⚜️with 关键词
      • ⚜️逐行读取
    • 3️⃣写入文件
      • ⚜️写入文件write()
      • ⚜️写入数字
      • ⚜️追加内容到文件
    • 4️⃣读取和写入二进制文件

简介

读完本篇你将学会文件的创建、读取、写入等。


1️⃣基本语法

在Python中使用文件的关键函数是open()函数。open()函数有两个参数:文件名(file)模式(mode)

open()函数的基本格式如下⬇️:

file_obj = open(file,mode=“r”)

完整的语法格式为⬇️:

open(file, mode=‘r’, buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

file_obj:文件对象,根据自己的喜好命名。不使用时要及时关闭,使用close()函数,才能返回操作系统的文件管理观察执行结果。

file:文件名。可以是相对路径或绝对路径。

mode:打开文件的模式。默认是:mode='rt'

以下是文件的四种模式:

  • "r":读取。打开文件进行读取,如果不存在则报错。

  • "w":写入。打开文件进行写入,如果文件存在内容会被覆盖。

  • "a":追加。向原有的文件追加内容,如果没有则创建。

  • "x":创建。创建文件,如果文件存在则报错。

以下是两种文件类型:

  • "t":文本模式,默认值。
  • "x":二进制模式(例:图像)



2️⃣读取文件

⚜️读取整个文件read()

read()方法用于读取文件。可以使用size限制读取的字符数。

read()函数的基本格式如下⬇️:

file_obj.read([size])

案例⬇️:

f = open('sse','r')         # sse想要打开的文件名 r 打开模式默认是r,可省略
read_file = f.read(78)     # 将读取的文件保存到变量read_file中 78:限定输出的字符数
f.close()           		# 关闭文件
print(read_file)         		# 输出变量read_file相当于输出文件

执行结果为⬇️:

在这里插入图片描述


⚜️with 关键词

with关键词应用在打开文件建立文件对象时。with最大的优点是不需要使用file_obj.close()关闭文件,with在文件使用结束时,会自动关闭文件。

with基本格式如下⬇️:

with open(file) as file_obj:

      读取代码

案例⬇️:

with open('k') as f:			# 默认读取方式为r,可省略。 不需要使用close关闭文件
    read_file = f.read()
    print(read_file)

执行结果为⬇️:

请添加图片描述


⚜️逐行读取

可以使用循环逐行读取文件内容。

逐行读取基本格式如下⬇️:

for i in file_obj :

      输出
案例⬇️:

fn = 'k'
with open(fn) as f:
    for i in f:				# 使用for循环遍历每一行
        print(i)			# 输出

执行结果为⬇️:

请添加图片描述

⭐原因:文本文件末尾有换行符,print结尾也有一个换行(end=‘\n’)。

🌟解决办法一:去除字符右边的空格

fn = 'k'
with open(fn) as f:
    for i in f:
        print(i.rstrip())           # 使用rstrip去除字符右边的空格

🌟解决办法二:更换结尾符

fn = 'k'
with open(fn) as f:
    for i in f:
        print(i,end='')             # 使用end=''替换默认的end='\n'



3️⃣写入文件

⚜️写入文件write()

**write()**方法用于写入文件。

write()函数的基本格式如下⬇️:

file_obj.write()

案例⬇️:

string = 'Now study Python.'         # 要写入的字符串

with open('out','w') as f:          # w:写入模式
    f.write(string)          		# write()函数写入字符串

执行结果为⬇️:

请添加图片描述


⚜️写入数字

write()方法不能写入数字,所以要对数字进行转换。

错误示范⬇️:

x = 100

with open('out2','w') as f:
    f.write(x)				# 此处会报错,类型错误。不能输入数字。

请添加图片描述

正确代码⬇️:

x = 100

with open('out2','w') as f:
    f.write(str(x))				# 将数字转换为字符串。

执行结果为⬇️:

请添加图片描述


⚜️追加内容到文件

向原有的文件追加内容,如果文件不存在,则创建再填加内容。

案例⬇️:

add = 'I love Python'         		# 要追加的字符串

with open('out','a') as f:          # a:追加模式
    f.write(add)                 	# 向文件out追加内容

执行结果为⬇️:

请添加图片描述




4️⃣读取和写入二进制文件

一般图片、音频文件等都是二进制文件。文件的默认类型是t(文本模式),二进制模式为b。所有读取文件使用’rb’,写入文件使用’wb’。

案例⬇️:

src = 'IronMan.jpg'				# 读取文件名
dst = 'IronMan1.jpg'			# 报存的文件名
tmp = ''						# 保存读取到的二进制

with open(src, 'rb') as f:		
    tmp = f.read()				# 读取 
    with open(dst, 'wb') as w:	
            w.write(tmp)		# 写入

执行结果为⬇️:请添加图片描述请添加图片描述




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

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

相关文章

ThreadLocal机制解读和源码分析

目录 线程数据共享和安全 -ThreadLocal 什么是 ThreadLocal 代码演示 创建Dog.java 创建Pig.java T2DAO.java T2DAO T1解读set T1Service 解读 get ThreadLocalTest这个是换一种法 ThreadLocal 原理分析图 1. ThreadLocal 原理分析图(重点 set 和 get) 线程数据共…

Go Fuzzing:发现你未曾发现的漏洞

文章目录 Fuzzing(模糊测试)要求示例模拟crash 总结参考资料 Fuzzing(模糊测试) go fuzz文档 对于软件开发者而言,一项重要的任务就是确保程序的安全性。而其中一种风险就是软件中可能存在的漏洞。传统的测试方法往往需要耗费大量的时间和人力,而使用F…

【C++: 模块二 ---运算符、流程控制语句】

C: 模块二 ---运算符、流程控制语句 一、运算符:1.1算数运算符:1.2赋值运算符:1.3比较运算符:1.4逻辑运算符:1.5三目运算符: 二、程序流程结构2.1顺序结构:2.2选择结构:&…

ChatGPT免费第一版本

最近利用空余时间做了一个供大家免费体验的chatgpt国内可直接访问的版本 输入12345gpt.com可直接访问 贴上GPT给我回复的内容,😀 当今社会,交流已经成为人们日常不可或缺的一部分。然而,随着技术的发展,人们对于交流工…

【Linux 裸机篇(七)】I.MX6U 中断系统

目录 一、中断向量表1. 中断向量偏移 二、中断系统简介1. 创建中断向量表 三、GIC 控制器简介1. 中断 ID 四、GIC 逻辑分块1. Distributor(分发器端)2. CPU Interface(CPU 接口端) 五、CP15 协处理器六、中断使能1. IRQ 和 FIQ 总中断使能2. ID0~ID1019 中断使能和禁止 七、中断…

【PXE高效的批量网络装机】

目录 一、PXE的概述1.1、PXE批量部署的优点1.2、搭建PXE满足的以下的前提条件1.3、搭建PXE远程安装 二、搭建PXE远程安装服务器1、安装并启动 TFTP 服务2、安装并启用 DHCP 服务3、准备 Linux 内核、初始化镜像文件4、准备PXE 引导程序5、安装FTP服务,准备CentOS 7 …

SpringMVC使用域对象共享数据

1、SpringMVC中的域对象 此处只有request、session、servletContext被使用,而page是jsp页面的域,不使用jsp。 request:一次请求的范围内session:一次会话的范围内servletContext:整个web的应用范围内 2、向request域…

MySQL高级第十七篇:数据库主从复制原理及保证数据一致性

MySQL高级第十七篇:数据库主从复制原理及保证数据一致性 一、概述1. 提升数据库的并发能力2. 主从复制的作用? 二、主从复制原理三、搭建一主一从环境四、如何解决数据一致性问题?1. 方案一、异步复制2. 方案二、半同步复制3. 方案三、组复制…

3.黑马Springboot原理篇自己修改笔记

原理篇 1.自动配置的工作流程 1.1 bean的加载方式 方式一&#xff1a;配置文件<bean/>标签 缺点&#xff1a;配置bean太繁琐 方式二&#xff1a;配置文件扫描注解定义bean⭐️ 获取bean方式 ①通过配置文件&#xff0c;扫描指定包&#xff0c;加载bean ②通过注解声…

C++ STL之string容器的模拟实现

目录 一、经典的string类问题 1.出现的问题 2.浅拷贝 3.深拷贝 二、string类的模拟实现 1.传统版的string类 2.现代版的string类&#xff08;采用移动语义&#xff09; 3.相关习题* 习题一 习题二 4.写时拷贝 5.完整版string类的模拟实现[注意重定义] MyString.h…

磁珠的工作原理

磁珠是一个耗能元器件&#xff0c;他能把频率相对较高的信号以热量的形式耗散掉&#xff0c;保留频率相对较低的信号。 主要有这种插件的磁珠&#xff0c;还有这种贴片的磁珠。 下面我们来看下磁珠具体工作原理。 磁珠的构造我们可以简单的看成一个导线穿过环形铁氧体的磁性材…

[渗透教程]-015-网络与系统渗透

文章目录 1.0基本概念2.0 网络与系统渗透基本原理2.1 渗透测试2.2 入侵和预防2.3 案例一:从信息收集到入侵提权2.3.1 从域名到ip2.3.2 从IP获取旁站2.3.3 收集系统与⽹络配置详细信息2.3.4 踩点2.3.5发现漏洞2.3.6漏洞利用2.3.7维持系统控制权2.3.8清理访问痕迹2.4 案例二:Goo…

TryHackMe-Jeff(boot2root | Hard?)

Jeff 你能破解杰夫的网络服务器吗&#xff1f; 如果你发现自己在暴力破解SSH&#xff0c;你就做错了。 端口扫描 循例nmap 进80&#xff0c;是一个空页面&#xff0c;查看源代码 将jeff.thm加入hosts 上gobuster /admin是空页面&#xff0c;/backups也没东西&#xff0c;/up…

Centos安全加固策略

目录 密码安全策略 设置密码的有效期和最小长度 设置用户密码的复杂度 登录安全策略 设置用户远程登录的安全策略 安全的远程管理方式 访问控制 限制root用户登录 修改ssh 22端口 设置登录超时时间 限制IP访问 安全审计 审核策略开启 日志属性设置 查看系统登录…

基础巩固、探寻Java装箱和拆箱的奥妙!

前言 今天在逛某知名论坛的时候&#xff0c;看到一篇"请不要使用包装类型&#xff0c;避免造成性能损失"的文章。一下子就吸引了我的注意。大意就是&#xff0c;能用基本数据类型就尽量用基本数据类型&#xff0c;因为包装类型自动拆箱、装箱会带来性能损失尤其是循环…

函数式编程#3纯函数的概念

纯函数的概念 文章目录 纯函数的概念纯函数的两种形式&#xff1a;调用目标本身,不会改变函数内部,不受函数外部影响 函数的副作用如何理解"相同的输入得到相同的输出"不是纯函数的映射关系是纯函数的映射关系 纯函数的两种形式&#xff1a; 调用目标本身,不会改变 …

gcc编译 与交叉编译(x86 to arm) (一)单个文件编译

1.1、gcc编译单个c程序&#xff08;hello.c) gcc hello.c -o hello (hello是生成的可执行程序的名字&#xff09;1.2、交叉编译hello.c 源平台&#xff1a; UOS_X86_64 目标平台&#xff1a;UOS_arm 方法&#xff1a;使用现成的交叉编译工具链 参考资料&#xff1a;交叉编译…

【UE】water插件的简单使用

UE Editor版本&#xff1a;4.26 目录 一、岛屿外观修改 二、波浪参数设置 三、水体海洋的颜色设置 四、 水体河流 五、创建可浮在水体上的actor 一、岛屿外观修改 1. 保证“Landmass”和“Water”插件已启用 启用后&#xff0c;搜索water可以看到如下组件 2. 激活地形编…

LeetCode:6390. 滑动子数组的美丽值

&#x1f34e;道阻且长&#xff0c;行则将至。&#x1f353; &#x1f33b;算法&#xff0c;不如说它是一种思考方式&#x1f340; 算法专栏&#xff1a; &#x1f449;&#x1f3fb;123 一、&#x1f331;6390. 滑动子数组的美丽值 题目描述&#xff1a;给你一个长度为 n 的整…

vulnhub DC:4渗透笔记

靶场下载地址:https://vulnhub.com/entry/dc416-2016,168/ 信息收集 使用nmap确定靶场ip地址 扫描ip确定开放端口 开放22 80端口&#xff0c;访问一下网页端(这边断了一次靶机ip改为192.168.100.138) 漏洞利用 登录框尝试爆破 发现用户名密码admin happy 登录进入后发现这里…