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的字节串/字节数组和文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807028

相关文章

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文