Python I/O及FIle方法
一、文件操作
文件的编码格式:
ASCII与UNICODE:
计算机有256个ASCII字符(8个0/1的排列组合方式一共有256种, 2**8)
UTF-8是UNICODE的一种编码格式,计算机中使用1~6个字节来表示一个UTF-9字符,涵盖了地球上几乎所有地区的文字,汉字使用3个字节表示
open(file, mode = 'r', buffering = -1 , encoding=None, errors = None, newline = None, closefd = True,opener = None)
八个参数意义:
- file——可表示文件名,也可是相对当前目录的路径,或者是绝对路径;
- mode——设置文件的打开模式:r——只读(默认),w——写入(不存在则创建,存在则覆盖),x——文件存在抛异常,不存在则创建并写入,a——追加(若已存在则追加到文件末尾),+——更新模式。一般文本文件使用“r+,w+,x+,a+”,二进制文件采用“rb+,wb+,xb+,ab+”。
- buffering——缓冲策略,默认值-1,自动设置缓冲区4096或8192字节,当值为0时关闭缓冲区,数据将直接被写入文件。使用缓冲区是为了提高效率减少IO操作,当文件关闭或刷新缓冲区时,数据才真正被写入。
- encoding和errors——打开文件编码、发生错误时处理方案
- newline——设置换行模式
- closefd和opener——调用close方法关闭文件,opener是打开文件时执行的一些加工操作,返回一个文件描述符。
一般只使用前两个参数。
文件内容读取:
filename = 'E:/a.txt'
try:
f = open(filename)
except OSError:
print('打开文件失败')
else:
try:
content = f.read()
print(content)
except OSError:
print('文件读取失败')
finally:
f.close()
注意:
在编写代码时,最好是open之后立即编写文件关闭方法,即close(),以免忘记关闭文件,造成系统资源损耗,影响后续对其他文件的访问。
在读取文件时,read方法将一次性读取文件所有内容,读取文件的指针将会从开头一直移动到末尾。
在第一次read读取之后,再次调用read()方法,将不能够获取到内容,因为此时文件指针移动到了文件末尾。
简单代码:
with open('E:/a.txt', 'r') as f:
content = f.read()
print(content)
读取文件并复制(w——写入(不存在则创建,存在则覆盖)):
filename = 'E:/a.txt'
with open(filename, 'r', encoding='utf-8') as f:
lines = f.readlines()
print(lines)
copy_f_name = 'E:/copy_a.txt'
with open(copy_f_name, 'w', encoding='utf-8') as copy_f:
copy_f.writelines(lines)
print('{}成功复制到{}'.format(filename, copy_f_name)) 结果:
['hellohellohellohello']
E:/a.txt成功复制到E:/copy_a.txt
二进制文件读写:
- read(size = -1):size限制读取的行数,size = -1时读取全部字节
- readline(size = -1)读取并返回一行,参数同上
- readlines(hint = -1)读取数据到一个列表中,每一个行数据是列表的一个元素,hint限制读取的行数,值为-1是不限制
- write(b):写入b字节,并返回字节数
- writelines(lines):向文件中写入一个列表,不添加分隔符,每一行末尾提供分隔符
- flush(),刷新缓冲区,将缓冲区数据写入文件中。
二进制文件复制(wb——二进制文件写入(不存在则创建,存在则覆盖)):
filename = 'E:/头像.jpg'
with open(filename,'rb') as f:
b = f.read()
copy_f_name = 'E:/头像_Copy.jpg'
with open(copy_f_name,'wb') as copy_f:
copy_f.write(b)
print('二进制文件复制成功!')
二、OS模块——系统目录与文件的管理:
- os.rename(src, dst):修改源文件src成目标文件dst,可为相对路径或绝对路径;
- os.remove(path):删除path目录下指定文件,若为路径,则OSError;
- os.mkdir(path):创建path目录,若已存在,则FileExistsError;
- os.rmdir(path):删除path目录:目录非空,则OSError;
- os.walk(top):遍历top目录树,自上而下,返回三元组(目录路径,目录列表,文件名列表);
- os.listdir(dir):列出指定目录中的文件和子目录;
- os.curdir:获得当前目录;
- os.pardir:获得当前父目录。
import os f_name = 'E:/a.txt'
copy_f_name = 'E:/a_copy.txt'
with open(f_name, 'r') as f:
b = f.read()
with open(copy_f_name, 'w') as copy_f:
copy_f.write(b)
# 判断是否存在,否则文件重命名
try:
os.rename(copy_f_name, 'E:/b.txt')
except OSError:
os.remove('E:/b.txt')
# 输出当前目录及父目录
print(os.listdir(os.curdir))
print(os.listdir(os.pardir))
# 判断路径是否存在,否则删除路径
try:
os.mkdir('E:/filesdir')
except OSError:
os.rmdir('E:/filesdir')
for i in os.walk('E:/桌面'):
print(i)
结果:


三、os.path模块
- os.path.abspath(path)——返回绝对路径
- os.path.basename(path)——返回基础名(如果path指向文件,则返回文件名,指向目录,则返回最后目录名)
- os.path.dirname(path)——返回path中的目录
- os.path.exists(path)——path是否存在
- os.path.isdir(path)——path是文件,返回True
- os.path.getatime(path)——path是目录,返回True
- os.path.getmtime(path)——返回最后访问时间(自1970-1-1 00:00:00来的总秒数)
- os.path.getctime(path)——返回最后修改时间(自1970-1-1 00:00:00来的总秒数)
- os.path.getsize(path)——返回文件大小,单位字节。
示例:
import os.path
from datetime import datetime f_name = '抢火车票.py'
all_name = r'C:\Users\Jery\PycharmProjects\CollectImages\抢火车票.py'
# 基础名部分
basename = os.path.basename(all_name)
print(basename)
# 目录部分
dirname = os.path.dirname(all_name)
print(all_name)
# 绝对路径
print(os.path.abspath(f_name))
# 文件大小
print(os.path.getsize(f_name))
# 最近访问时间
atime = datetime.fromtimestamp(os.path.getatime(f_name))
print(atime)
# 最近修改时间
mtime = datetime.fromtimestamp(os.path.getmtime(f_name))
print(mtime)
# 创建时间
ctime = datetime.fromtimestamp(os.path.getctime(f_name))
print(ctime) print(os.path.isdir(dirname))
print(os.path.isfile(f_name))
print(os.path.exists(f_name)) 结果:
抢火车票.py
C:\Users\Jery\PycharmProjects\CollectImages\抢火车票.py
C:\Users\Jery\PycharmProjects\CollectImages\抢火车票.py
5673
2019-03-27 11:19:39.251669
2019-03-27 11:19:39.251669
2019-03-15 19:48:48.315313
True
True
True Process finished with exit code 0
Python I/O及FIle方法的更多相关文章
- Ubuntu下 fatal error: Python.h: No such file or directory 解决方法
参考: fatal error: Python.h: No such file or directory Ubuntu下 fatal error: Python.h: No such file or ...
- python之file 方法
file 对象使用 open 函数来创建,下表列出了 file 对象常用的函数: 1 file.close() close() 方法用于关闭一个已打开的文件.关闭后的文件不能再进行读写操作, 否 ...
- sqlalchemy mark-deleted 和 python 多继承下的方法解析顺序 MRO
sqlalchemy mark-deleted 和 python 多继承下的方法解析顺序 MRO 今天在弄一个 sqlalchemy 的数据库基类的时候,遇到了跟多继承相关的一个小问题,因此顺便看了一 ...
- python子类调用父类的方法
python子类调用父类的方法 python和其他面向对象语言类似,每个类可以拥有一个或者多个父类,它们从父类那里继承了属性和方法.如果一个方法在子类的实例中被调用,或者一个属性在子类的实例中被访问, ...
- python字符串常用内置方法
python字符串常用内置方法 定义: 字符串是一个有序的字符的集合,用与存储和表示基本的文本信息. python中引号中间包含的就是字符串. # s1='hello world' # s2=&quo ...
- python类:magic魔术方法
http://blog.csdn.net/pipisorry/article/details/50708812 魔术方法是面向对象Python语言中的一切.它们是你可以自定义并添加"魔法&q ...
- qingstor python-sdk 安装错误 src/MD2.c:31:20: fatal error: Python.h: No such file or directory
ubuntu安装python qingstor-sdk, src/MD2.c:31:20: fatal error: Python.h: No such file or directory compi ...
- python文件的md5加密方法
本文实例讲述了python文件的md5加密方法.分享给大家供大家参考,具体如下: 一.简单模式: from hashlib import md5 def md5_file(name): m = md5 ...
- Python打包文件夹的方法小结(zip,tar,tar.gz等)
本文实例讲述了Python打包文件夹的方法.分享给大家供大家参考,具体如下: 一.zip ? 1 2 3 4 5 6 7 8 9 10 11 import os, zipfile #打包目录为zip文 ...
随机推荐
- Eclipse中新建applet 错误
出现的问题: “错误,请单击以获取详细信息” Java Plug-in 1.6.0_45 使用 JRE 版本 1.6.0_45-b06 Java HotSpot(TM) Client VM 用户主目 ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(4):JDK动态代理+拦截器
一.拦截器的理解 学习拦截器之前需要对动态代理和反射有一定的基础. 官方说法: java里的拦截器是动态拦截Action调用的对象.它提供了一种机制可以使开发者可以定义在一个actio ...
- 编写高质量代码改善C#程序的157个建议——建议32:总是优先考虑泛型
建议32:总是优先考虑泛型 泛型的优点是多方面的,无论泛型类还是泛型方法都同时具备可重用性.类型安全性和高效率等特性,这是非泛型和非泛型方法无法具备的. 以可重用性为例: class MyList { ...
- 一步之遥——第七届蓝桥杯C语言B组(国赛)第一题
原创 一步之遥 从昏迷中醒来,小明发现自己被关在X星球的废矿车里.矿车停在平直的废弃的轨道上.他的面前是两个按钮,分别写着“F”和“B”. 小明突然记起来,这两个按钮可以控制矿车在轨道上前进和后退.按 ...
- Mongo Windows 基本使用入门
1.安装https://www.mongodb.com/download-center#community注意:安装 "install mongoDB compass" 不勾选下载 ...
- [.net 多线程]Monitor
Monitor 类通过向单个线程授予对象锁来控制对对象的访问.对象锁提供限制访问代码块(通常称为临界区)的能力.当一个线程拥有对象的锁时,其他任何线程都不能获取该锁.还可以使用 Monitor 来确保 ...
- Druid连接池默认配置和坑
一.公司默认配置 ds_0: !!com.alibaba.druid.pool.DruidDataSource driverClassName: com.mysql.jdbc.Driver url: ...
- python参数传递:对象的引用
大家都知道在python中,一切皆对象,变量也不再具有类型,变量仅仅是对象的一个引用,我们通常用变量来测类型,通常测得就是被这个变量引用得对象的类型. python采用的是传递对象的引用,为了方便说明 ...
- 跟我一起读postgresql源码(五)——Planer(查询规划模块)(下)
上一篇我们介绍了查询规划模块的总体流程和预处理部分的源码.查询规划模块再执行完预处理之后,可以进入正式的查询规划处理流程了. 查询规划的主要工作由grouping_planner函数完成.在具体实现的 ...
- linux下配置apache多站点访问-小案例
一级域名(baidu.com)也叫作顶级域名,注册一级域名是需要付费的. 而二级域名(image.baidu.com)是一级域名的延伸,所以只要购买了一级域名,二级域名是可以任意配置的. 其实(www ...