Skr-Eric的Python课堂(十八)——Python的字节串/字节数组和文件

2024-03-14 03:10

本文主要是介绍Skr-Eric的Python课堂(十八)——Python的字节串/字节数组和文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

序列的种类:

  字符串 str

  列表 list

  元组 tuple

  字节串 bytes

  字节数组 bytearray

 

字节串和字节数组

字节串(也叫字节序列) bytes

  作用:

    存储以字节为单位的数据

    字节串是不可变的字节序列

 

字节:

  字节是0~255之间的整数,字节是数据传输和数据存储的基本单位

    (例如:中国移动的流量...,文件大小等)

  

创建空字节串的字面值

  b''

  b""

  b""""""

  b''''''

创建非空的字节串的字面值

  b'ABCD'

  b"ABCD"

  b'\x41\x42'

 

字节串的构造函数:

   bytes()  # 生成一个字的字节串,等同于 b''

   bytes(整型可迭代对象)  用可迭代对象创建一个字节串

   bytes(整数n)  生成n个值为0的字节串

   bytes(字符串, encoding='utf-8')  用字符串的转换编码生成一个字节串

示例:

b = bytes()  
b = bytes(range(65, 90))
b = bytes(10)
b = bytes('hello', 'utf-8')
b = bytes('中文', 'utf-8')

bytes 的运算:

  与其它序列的运算规则完全相同

  + += * *=

  < <= > >= == !=

  in / not in

  索引和切片

len(x), max(x), min(x), sum(x), any(x), all(x)

 

bytes 与 str的区别

  bytes 存储字节(0~255)

  str 存储字符(用来表示文字信息,值为0~65535或更大)

 

bytes与 str转换

        编码(encode)

  str   ---------->  bytes

    b = s.encode(encoding='utf-8')

 

         解码(decode)

  bytes  ---------> str

    s = b.decode(encoding='utf-8')

 

字节数组 bytearray

  可变的字节序列

构造函数:

   bytearray()  # 生成一个字的字节串

   bytearray(整型可迭代对象)  用可迭代对象创建一个字节数组

   bytearray(整数n)  生成n个值为0的字节数组

   bytearray(字符串, encoding='utf-8')  用字符串的转换编码生成一个字节数组

 

运算和字节串完全相同

  * *= + +=

  < <= > >= == !=

  in / not in

  索引 index / 切片 slice

  字节数组支持索引和切片赋值(重要)

 

文件 File

  什么是文件

    文件是用于数据存储的单位

    文件通常用来长期存储数据

    文件中的数据是以字节(byte)为单位进行存储的

 

文件的操作流程:

   1. 打开文件

   2. 读/写文件

   3. 关闭文件

   注:任何操作系统,一个应用程序同时打开文件的数量有最大数限制

 

文件的打开函数:

  open(file, mode='rt')  用于打开一个文件,返回此文件对应的文件流对象,如果打开失败则会触发OSError错误

 

文件的关闭方法:

  F.close()  # 关闭文件,释放系统资源

示例:

# 此示例示意文件 的打开和关闭
try:# f = open("mynote.txt")  # 打开文件f = open('/home/tarena/aid1807/pbase/day16/code/mynote.txt')print("文件打开成功")f.close()print("文件已关闭")
except OSError:print("文件打开失败")

 

文本文件的操作:

  文本文件的模式字符 't'

  说明:

    1. 对文本文件的读写需要用字符串str 进行读取和写入数据

    2. 默认文件中存储的都是字符(文字)数据,在读写中会自动进行编码转换操作

    3. 以行为单位分隔,在python内统一用'\n'作用换行符进行分隔

 

  各操作系统的换行符:

    Linux换行符:        '\n'

    Windows 换行符:     '\r\n'

    旧的Macintosh换行符: '\r'

    新的Mac OS 换行符:  '\n'

 

文本文件读方法:

  F.readline()

  F.readlines()

  F.read([字符数或字节数])

示例:

# 此示例示意文件 的打开及读取文本信息的操作
try:f = open("mynote.txt")  # 打开文件print("文件打开成功")# 读写文件s = f.readline()  # 读取一行  s='abcd\n'print('len(s)=', len(s), '内空是', s)s = f.readline()  # 再读取一行 s = '1234'print('len(s)=', len(s), '内空是', s)s = f.readline()  # 再读取第三行 s = '' print('len(s)=', len(s), '内空是', s)# 关闭文件f.close()print("文件已关闭")
except OSError:print("文件打开失败")

 

文本文件的写方法

  模式字符串: 'w'/'x'/'a'

  F.write(字符串)

  F.writelines(字符串列表)

示例:

# f = open("newfile")
# 如果不写第二个参数默认是:  f = open('newfile', 'rt')
try:# f = open("/root/newfile.txt", 'wt')  # 失败抛出异常错误通知f = open("newfile.txt", 'w')# f = open("newfile.txt", 'x')  # 如果原文件存在,则报错# f = open("newfile.txt", 'a')  # 如果原文件存在,则报错print("打开成功")# 在此处进行写文件操作f.write("hello")f.write("world")f.writelines(['123456\n', 'abcdef\n'])f.close()print("关闭文件成功")
except OSError:print("创建文件失败")

 

文件的迭代读取

  文件流对象是可迭代对象,迭代过程将以换行符'\n'作用分隔符依次获取

示例:

f = open('mynote.txt', 'rt')
for line in f:  # f绑定的文件流对象是可迭代对象print(line)

 

标准输入输出文件:

  sys.stdin 标准输入文件(默认为键盘设备)

  ctrl + d  快捷键是让键盘输入文件结束符

  sys.stdout 标准输出文件 (默认为屏幕终端)

  sys.stderr 标准错误输出文件(默认为屏幕终端)

   模块名: sys

 

  说明:

    1. 标准文件不需要打开和关闭就可以使用

    2. 每一个python程序启动后都会有以上三个文件供我们使用

  示例:

# 此示例示意标准输入文件 sys.stdin 的用法
import sys
s = sys.stdin.readline()
print(s)
sys.stdin.close()  # 关闭标准输入文件则input函数就不能用了
s2 = input("请输入:")
print(s2)
# 此示例示意标准输入文件 sys.stdin 的用法
import sys
s = sys.stdin.read()
print(s)
import sys
sys.stdout.write("我是一个标准输出\n")
sys.stderr.write("我的出现是个错误!!!\n")
print("hello", 'world', file=sys.stdout)
f =open("myfile.txt", 'w')
print("你好!", "我在文件里", file=f)
f.close()

 

二进制文件操作:

  模式字符: 'b'

  默认文件中存储的都是以字节为单位的数据,通常有人为的格式

  对二进制文件的读写需要用字节串(bytes) 进行操作

 

常用的操作方法:

  F.read([字节数/字符数])

    对于文本文件, F.read()返回类型为字符串str

    对于二进制文件,F.read()返回类型为字节串bytes

  F.write()

    同上,对于二进制文件,写入的数据为字节串bytes或bytearray

F.tell() 方法

  返回当前文件流的读写位置(从0开始,以字节为单位)

F.seek方法

  作用:

    设置文件的读写位置

  格式:

    F.seek(偏移量, whence=相对位置)

      偏移量

        大于0代表向文件尾方向移动

        小于0代表向文件头方向移动

      相对位置

        0 代表从文件头开始偏移

        1 代表从当前位置开始偏移

        2 代表从文件尾开始偏移

  示例:

# 此示例示意seek方法的用法
f = open('20.txt', 'rb')  # 二进制方式打开
b = f.read(3)  # 读了三个字节
print(b)
# f.seek(5, 0)  # 代表从文件头向后移动5个字节
# f.seek(2, 1)  # 代表从当前位置向后移动2个字节
f.seek(-15, 2)  # 代表从文件尾向前移动15个字节
b = f.read(5)
print(b)  # b'ABCDE'
f.close()

 

课后习题:

  1. 写程序,让用户输入一系列整数,当输入小于零的数时结束输入

    1) 将这些数字存于列表中

    2) 将列表中的数字写入到文件numbers.txt中

    (提示:需要将整数转为字符串或字节串才能存入文件中)

  2. 写程序,将上题的numbers.txt中的整数读入到内存中形成列表

    计算这些数中的最大值,最小值和它们的和

 

  3. 写程序,实现复制文件功能

    要求:

      1) 要考虑关闭文件问题

      2) 要考虑超大文件复制问题

      3) 要能复制二进制文件(如:/usr/bin/python3 等文件)

 

  4. 将学生信息管理程序添加两个功能:

     | 9)  保存信息到文件(si.txt)   |

     | 10) 从文件中读取数据(si.txt) |

 

 

想要看更多的课程请微信关注SkrEric的编程课堂

这篇关于Skr-Eric的Python课堂(十八)——Python的字节串/字节数组和文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/Skr_Eric/article/details/102570630
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/807028

相关文章

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

Python自动化批量重命名与整理文件系统

《Python自动化批量重命名与整理文件系统》这篇文章主要为大家详细介绍了如何使用Python实现一个强大的文件批量重命名与整理工具,帮助开发者自动化这一繁琐过程,有需要的小伙伴可以了解下... 目录简介环境准备项目功能概述代码详细解析1. 导入必要的库2. 配置参数设置3. 创建日志系统4. 安全文件名处

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数