python总结高阶-文件

文章目录

  • 文件操作
  • 文本文件和二进制文件
    • 1 文本文件
    • 2 二进制文件
  • 文件操作相关模块
  • 创建文件对象open()
  • 文本文件的写入
    • 基本的文件写入操作
    • 常用编码介绍
    • write()/writelines()写入数据
    • close()关闭文件流
    • with语句(上下文管理器)
  • 文本文件的读取
    • read([size])
    • readline()
    • readlines()
  • 二进制文件的读取和写入
  • 文件对象的常用属性和方法
  • 文件任意位置操作
  • 使用pickle序列化 (很重要)
    • 【操作】将对象序列化到文件中
    • 【操作】将获得的数据反序列化成对象
  • CSV文件的操作
    • csv.reader对象和csv文件读取
    • csv.writer对象和csv文件写入
  • os和os.path模块
    • os模块-调用操作系统命令
    • os.startfile :直接调用可执行文件
    • os模块-文件和目录操作
    • os 模块下常用操作文件的方法
    • os 模块下关于目录操作的相关方法,汇总如下:
    • os.path模块
    • walk()递归遍历所有文件和目录
  • 递归遍历目录下所有文件

文件操作

在这里插入图片描述

文本文件和二进制文件

按文件中数据组织形式,我们把文件分为文本文件和二进制文件两
大类。

1 文本文件

文本文件存储的是普通“字符”文本,python默认为 unicode 字符集
(两个字节表示一个字符,最多可以表示:65536个),可以使
用记事本程序打开。

2 二进制文件

二进制文件把数据内容用“字节”进行存储,无法用记事本打开。必
须使用专用的软件解码。常见的有:MP4视频文件、MP3音频文
件、JPG图片、doc文档等等。

文件操作相关模块

在这里插入图片描述

创建文件对象open()

open() 函数用于创建文件对象,基本语法格式如下:
open(文件名[,打开方式])
如果只是文件名,代表在当前目录下的文件。文件名可以录入全路
径,比如: D:\a\b.txt
为了减少 \ 的输入,可以使用原始字符串: r“d:\b.txt” 示例如下:
f = open(r"d:\b.txt",“w”)
打开方式有如下几种:
在这里插入图片描述

文本文件的写入

基本的文件写入操作

文本文件的写入一般就是三个步骤:
1 创建文件对象
2 写入数据
3 关闭文件对象

f = open(r"a.txt","a")
s = "itbaizhan\nsxt\n"
f.write(s)
f.close()
with open(r"a.txt","a") as f:s = "itbaizhan\nsxt\n"f.write(s)

常用编码介绍

在操作文本文件时,经常会操作中文,这时候就经常会碰到乱码问
题。为了让大家有能力解决中文乱码问题,这里简单介绍一下各种
编码之间的关系。
常用编码之间的关系如下:

在这里插入图片描述

#测试写入中文
2 f = open(r"b.txt","w",encoding="utf-8")
3 f.write("尚学堂\n百战程序员\n")
4 f.close()

write()/writelines()写入数据

write(a) :把字符串 a 写入到文件中
writelines(b) :把字符串列表写入文件中,不添加换行符

f = open(r"d:\bb.txt","w",encoding="utf-8")
s = ["高淇\n","高老三\n","高老四\n"]
f.writelines(s)
f.close()

在这里插入图片描述

close()关闭文件流

在这里插入图片描述
由于文件底层是由操作系统控制,所以我们打开的文件对象必须显
式调用 close() 方法关闭文件对象。当调用 close() 方法时,首先会把缓冲
区数据写入文件(也可以直接调用 flush() 方法),再关闭文件,释放文
件对象

with语句(上下文管理器)

with关键字 (上下文管理器)可以自动管理上下文资源,不论什么原因
跳出 with块 ,都能确保文件正确的关闭,并且可以在代码块执行完毕
后自动还原进入该代码块时的现场。

s = ["高淇\n","高老三\n","高老五\n"]
with  open(r"d:\bb.txt","w") as f:f.writelines(s)

文本文件的读取

文件的读取一般使用如下三个方法:

read([size])

从文件中读取 size 个字符,并作为结果返回。如果没有 size 参
数,则读取整个文件。
读取到文件末尾,会返回空字符串。

readline()

读取一行内容作为结果返回。读取到文件末尾,会返回空字符串

readlines()

文本文件中,每一行作为一个字符串存入列表中,返回该列表

二进制文件的读取和写入

二进制文件的处理流程和文本文件流程一致。首先还是要创建文件
对象,不过,我们需要指定二进制模式,从而创建出二进制文件对
象。例如:

f = open(r"d:\a.txt", 'wb') #可写的、重写模式的二进制文件对象
f = open(r"d:\a.txt", 'ab') #可写的、追加模式的二进制文件对象
f = open(r"d:\a.txt", 'rb') #可读的二进制文件对象

创建好二进制文件对象后,仍然可以使用 write() 、 read() 实现文件的读
写操作

文件对象的常用属性和方法

文件对象封装了文件相关的操作。在前面我们学习了通过文件对象
对文件进行读写操作。本节我们详细列出文件对象的常用属性和方
法,并进行说明。
文件对象的属性
在这里插入图片描述
文件对象的打开模式
在这里插入图片描述
文件对象的常用方法
在这里插入图片描述

文件任意位置操作

#e.txt的内容是:abcefghljklmn
with open("e.txt","r",encoding="utf-8") as f:print("文件名是:{0}".format(f.name))  #文件名是:e.txtprint(f.tell())                      #0print("读取的内容:{0}".format(str(f.readline()))) #读取的内容:abcdefghijklmnprint(f.tell())                      #14f.seek(3,0)print("读取的内容:{0}".format(str(f.readline()))) #读取的内容:defghijklmn

使用pickle序列化 (很重要)

我是编程ID

序列化使用:

pickle.dump(obj, file) obj 就是要被序列化的对象, file 指的是存储的文件
pickle.load(file)从 file 读取数据,反序列化成对象

【操作】将对象序列化到文件中

import picklewith  open("data.dat","wb") as f:name = "高淇"age = 34score = [90,80,70]resume ={'name':name,'age':age,'score':score}pickle.dump(resume,f)

【操作】将获得的数据反序列化成对象

import pickle
with  open("data.dat","rb") as f:resume = pickle.load(f)print(resume)

CSV文件的操作

csv是逗号分隔符文本格式,常用于数据交换、Excel文件和数据库
数据的导入和导出。
在这里插入图片描述

csv.reader对象和csv文件读取


import csv
with  open(r"d:\a.csv") as a:a_csv = csv.reader(a)        #创建csv对象,它是一个包含所有数据的列表,每一行为一个元素headers = next(a_csv)        #获得列表对象,包含标题行的信息print(headers)for row in a_csv:           #循环打印各行内容print(row)

[‘姓名’, ‘年龄’, ‘工作’, ‘薪水’]
[‘高淇’, ‘18’, ‘程序员’, ‘50000’]
[‘高老三’, ‘19’, ‘测试工程师’, ‘20000’]
[‘高老五’, ‘20’, ‘人工智能开发’, ‘50000’]

csv.writer对象和csv文件写入

import csv
headers = ["工号","姓名","年龄","地址","月薪"]
rows = [("1001","高淇",18,"西三旗1号院","50000"),("1002","高八",19,"西三旗1号
院","30000")]
with  open(r"d:\b.csv","w") as b:b_csv = csv.writer(b)        #创建csv对象b_csv.writerow(headers)      #写入一行(标题)b_csv.writerows(rows)        #写入多行(数据)

os和os.path模块

os模块-调用操作系统命令

os.system 可以帮助我们直接调用系统的命令

import os
os.system("notepad.exe")
os.system("ping www.baidu.com")

os.startfile :直接调用可执行文件

import osos.startfile(r"C:\Program Files(x86)\Tencent\WeChat\WeChat.exe")

os模块-文件和目录操作

我们可以通过前面讲的文件对象实现对于文件内容的读写操作。如
果,还需要对文件和目录做其他操作,可以使用 os 和 os.path 模块。

os 模块下常用操作文件的方法

在这里插入图片描述

os 模块下关于目录操作的相关方法,汇总如下:

在这里插入图片描述

os.path模块

在这里插入图片描述

walk()递归遍历所有文件和目录

os.walk() 方法是一个简单易用的文件、目录遍历器,可以帮助我们高
效的处理文件、目录方面的事情。格式如下:
os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])
其中, top :是要遍历的目录。 topdown :可选, True ,先遍历 top 目录
再遍历子目录。
返回三元组( root 、 dirs 、 files ):
root :当前正在遍历的文件夹本身
dirs :一个列表,该文件夹中所有的目录的名字
files :一个列表,该文件夹中所有的文件的名

递归遍历目录下所有文件

import os
import os.path#递归遍历目录树def my_print_file(path,level):child_files = os.listdir(path)for file in child_files:file_path = os.path.join(path,file)print("\t"*level+file_path[file_path.rfind(os.sep)+1:])if os.path.isdir(file_path):my_print_file(file_path,level+1)my_print_file("电影",0)

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

离线部署的MinIO

网络有不同的部分,例如 DMZ、公共、私有、堡垒等。这实际上取决于您的组织和网络要求。在部署应用程序时,任何应用程序,我们都需要考虑类型以及它是否需要位于网络的特定部分。 例如,如果要部署数据库,则不希望它位于…

企业出海数据合规:GDPR中的个人数据与非个人数据之区分

GDPR仅适用于个人数据,这意味着非个人数据不在其适用范围内。因此,个人数据的定义是一个至关重要的因素,因为它决定了处理数据的实体是否要遵守该法规对数据控制者规定的各种义务。尽管如此,什么是个人数据仍然是当前数据保护制度…

CMU15-445-Spring-2023-Project #1 - 前置知识(lec01-06)

Lecture #01_ Relational Model & Relational Algebra Databases 数据库是相互关联的数据的有组织集合,对现实世界的某些方面进行建模。区别于DBMS(MySQL、Oracle)。 Flat File Strawman 数据库以CSV文件的形式存储,并由D…

呕心沥血总结的Python自动化测试面试题

📢专注于分享软件测试干货内容,欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!📢软件测试面试题分享: 1000道软件测试面试题及答案📢软件测试实战项目分享: 纯接口项目-完…

Oracle database 12cRAC异地恢复至单机

环境 rac 环境 byoradbrac Oracle12.1.0.2 系统版本:Red Hat Enterprise Linux Server release 6.5 软件版本:Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit byoradb1:172.17.38.44 byoradb2:172.17.38.4…

IP地址定位技术的应用及其重要性

随着网络技术的快速发展,网络安全问题日益凸显,IP地址定位技术在网络安全领域的应用也越来越广泛。本文将介绍IP地址定位技术在网络安全领域的应用及其重要性。 一、IP地址定位技术概述 IP地址定位技术是指通过一定的技术手段,将虚拟网络中的…

8、VS中Git使用

VS中Git使用 1.基础操作1.1 VS配置Git1.2 操作界面 2.本地库版本管理2.1 创建管理本地库2.2 暂存、存储2.3 提交2.4 版本切换 3.分支操作3.1 分支应用3.2 新建分支3.3 合并分支、解决冲突3.4 删除分支 4.远程库版本管理4.1 新建、克隆4.2 提取、拉取、推送与同步4.3 团队开发 最…

sublime text 3 分屏和关闭分屏

有时候需要编辑多个地方的代码,开多个编辑器又太麻烦,那么Sublime自带的分屏快捷键可以解决烦恼。 Altshift2 分为2列 Altshift3 分为3列 Altshift4 分为4列 Altshift5 分为2行2列 Altshift8 分为2行 Altshift9 分为3行 取消分屏:Alts…

【JAVA】OPENGL+TIFF格式图片,不同阈值旋转效果

有些科学研究领域会用到一些TIFF格式图片,由于是多张图片相互渐变,看起来比较有意思: import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.logging.*;/*** 可以自已定义日志打印格式…

Python课程设计基于python的人脸识别佩戴口罩系统设计

wx供重浩:创享日记 对话框发送:python口罩 获取完整论文报告源码源文件 1 研究背景与意义 新型冠状病毒展现出全球化流行和蔓延的趋势,这提醒我们:传染病防治在今后相当长时间内仍是疾病预测控制工作的重点。戴口罩是预防呼吸道…

网络实训模拟考察题目和答案(华为eNSP综合实验考试)

拓扑中四个交换机五个路由器,共九个设备 答案是对应的九个脚本(从设备命名到保存) 全部复制粘贴后,从PC1、PC2都是能Ping通服务器的(保及格),其他要求没检查 题目 VLAN信息 设备名称端口链路…

ssm基于JSP的明水县苹果网吧计费管理系统的设计与实现论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本明水县苹果网吧计费管理系统就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大…