python学习的第二十二天:文件读写

python学习的第二十二天:文件读写

关于文件的简单认知

  • 通过文件系统将数据储存到文件中,我们实现了数据的持久化

  • 计算机的文件系统是一种存储和组织计算机数据的方法,它使得对数据的访问和查找变得容易

  • 文件系统使用文件和树形目录的抽象逻辑概念代替了硬盘、光盘、闪存等物理设备的数据块概念

对文件的操作

文件的打开和关闭
  • 通过open函数打开,同时可以通过参数指定文件名、操作模式和字符编码等信息
操作模式具体含义
'r'读取 (默认)
'w'写入(会先截断/覆盖之前的内容)
'x'写入,如果文件已经存在会产生异常(创建)
'a'追加,将内容写入到已有文件的末尾
'b'二进制模式(图片)
't'文本模式(默认)
'+'更新(既可以读又可以写)

具体使用的方式如下:

使用open函数时可以通过encoding参数指定读写文件使用的字符编码,常用编码为utf- 8

  • 通过close关闭文件,释放文件占用的内存
文件读写
  • 通过read函数读取文件

    或者通过循环和readline逐次读行进行读取

file = open('resources/致橡树.txt', 'r', encoding='utf-8')
try:
    # 如果读不到数据,read方法会返回None
    data = file.read(32)
    while data:
        print(data, end='')
        data = file.read(32)
finally:
    file.close()
文件的指针操作
from io import SEEK_END, SEEK_SET

file = open(file='resources/guido.jpg', mode='rb')
# 如果希望获得文件的字节数,可以先用seek方法将文件指针移动到文件末尾
# 然后通过tell方法获取文件指针移动的字节数,这个字节数就是文件的大小
file.seek(0, SEEK_END)
print(file.tell())
# 将文件指针移动到文件最开始的位置
file.seek(0, SEEK_SET)
try:
    data = file.read(512)
    while data:
        print(data, end='')
        data = file.read(512)
finally:
    file.close()

计算python解释器的MD5哈希码
from hashlib import md5, sha256

hasher = md5()
# hasher2 = sha256()
file = open('resources/python-3.9.6-amd64.exe', 'rb')
try:
    data = file.read(512)
    while data:
        # 更新MD5对象的数据
        hasher.update(data)
        # hasher2.update(data)
        data = file.read(512)
finally:
    file.close()
# 获得十六进制形式的MD5哈希摘要
print(hasher.hexdigest())
# print(hasher2.hexdigest())
文件的复制
def file_copy(source_file, target_file):
    """文件拷贝"""
    with open(source_file, 'rb') as source:
        with open(target_file, 'wb') as target:
            data = source.read(512)
            while data:
                target.write(data)
                data = source.read(512)


if __name__ == '__main__':
    file_copy('C:/Users/29665/Pictures/猫.jpg')

对csv文件的操作
# 通过自带包工具csv对csv文件进行操作
import csv

with open('resources/temperature.txt') as file1:
    with open('resources/result.csv', 'w', encoding='gbk', newline='') as file2:
        writer = csv.writer(file2, delimiter='|')
        # 通过writerow进行csv文件的写操作
        # writerow方法的参数是一个列表或元组(代表一行中所有的数据,默认用逗号分隔)
        writer.writerow(['ID', 'temperature', 'information'])
        content = file1.readline()
        while content:
            # 解包操作
            no, temp = content.split()
            temp = float(temp)
            if temp >= 37.2:
                if temp <= 38.5:
                    info = '发热'
                else:
                    info = '高热'
                writer.writerow([no, temp, info])
            content = file1.readline()

通过write进行TXT文件的写操作
通过requests下载图片
import requests

# 连网获取数据
resp = requests.get('http://p6.toutiaoimg.com/img/pgc-image/SVlm41hHScGcOO~tplv-tt-cs0:850:285.jpg')
with open('resources/temp.png', 'wb') as file:
    file.write(resp.content)

def download_picture(picture_url, filename):
    """下载图片"""
    resp = requests.get(picture_url)
    with open(filename, 'wb') as file:
        file.write(resp.content)

download_picture(
    'https://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png',
    'resources/baidu.png'
)

# 生成随机码
import uuid

for _ in range(10):
    print(uuid.uuid1().hex)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

踏墟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值