零基础入门学习Python 09

简介: 零基础入门学习Python 09

1.文件打开

语法:file object = open(file_name [, access_mode][, buffering])

  • file_name:要访问的文件路径及名称的字符串值。
  • access_mode:决定了打开文件的模式:只读,写入,追加等。默认文件访问模式为只读®。
  • buffering:
  •              值取0,不会有寄存。
  •              值取1,访问文件时会寄存行。
  •              值取大于1的整数,表明了这就是的寄存区的缓冲大小。
  •              值取负值,寄存区的缓冲大小则为系统默认。
  • f = open('E:\\test1.txt', 'w')

  • 直接print(f),会输出一个文件对象:
  • <_io.TextIOWrapper name='D:\\test1.txt' mode='r' encoding='cp936'>

2.文件对象方法

  • list(f)能将文件直接转化为列表
  • 读取文件对象

for each_line in f:

print(each_line)

  • 注意:

文件写入后,关闭文件才能保存写入内容

f.write('i love ivcc')

f.close()

3.文件内容处理

1. def save_file(count, EM, YZ):
2. # 文件保存
3. if count != 0:
4.         file_name_EM = '恶魔_' + str(count) + '.txt'
5.         file_name_YZ = '勇者_' + str(count) + '.txt'
6.         EM_file = open(file_name_EM, 'w', encoding='utf-8')
7.         YZ_file = open(file_name_YZ, 'w', encoding='utf-8')
8. 
9.         EM_file.writelines(EM)
10.         YZ_file.writelines(YZ)
11. 
12.         EM_file.close()
13.         YZ_file.close()
14. 
15. 
16. def main_split_file():
17.     EM = []
18.     YZ = []
19.     count = 0
20. 
21.     f = open('.\\file内容分割test_file.txt', encoding='utf-8')
22. for each_line in f:
23. print(each_line)
24. if each_line[:6] != '======':
25. # 按照:分割字符串,保存到序列
26. if count != 0:
27.                 (role, line_spoken) = each_line.split(':', 1)
28. if role == '恶魔':
29.                     EM.append(line_spoken)
30. if role == '勇者':
31.                     YZ.append(line_spoken)
32. else:
33.             save_file(count, EM, YZ)
34.             EM = []
35.             YZ = []
36.             count += 1
37.     save_file(count, EM, YZ)
38.     f.close()
39. 
40. 
41. if __name__ == '__main__':
42.     main_split_file()

4.文件系统

OS模块

访问文件系统的模块,用来处理文件和目录

OS: Operating System 操作系统

os基本方法

  • 注:
  • '.'表示当前目录
  • '…'表示上一级目录
  • 路径操作中常用到的一些定义
  • os.curdir 指代当前目录(’.’)
  • os.pardir 指代上一级目录(’…’)
  • os.sep 输出操作系统特定的路径分隔符(Win下为’\’,Linux下为’/’)
  • os.linesep 当前平台使用的行终止符(Win下为’\r\n’,Linux下为’\n’)
  • os.name 指代当前使用的操作系统(包括:‘posix’, ‘nt’, ‘mac’, ‘os2’, ‘ce’, ‘java’)

os.path

5.永久储存

pickle模块

“Pickling”是将Python对象层次结构转换为二进制字节流的过程,

“unpickling”是反向操作

作用:

  • 简化程序,将大量的数据打包(如: 城市字典)成二进制文件,需要使用时调用即可
相关文章
|
23天前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
43 3
|
4天前
|
Python 容器
Python学习的自我理解和想法(9)
这是我在B站跟随千锋教育学习Python的第9天,主要学习了赋值、浅拷贝和深拷贝的概念及其底层逻辑。由于开学时间紧张,内容较为简略,但希望能帮助理解这些重要概念。赋值是创建引用,浅拷贝创建新容器但元素仍引用原对象,深拷贝则创建完全独立的新对象。希望对大家有所帮助,欢迎讨论。
|
6天前
|
存储 索引 Python
Python学习的自我理解和想法(6)
这是我在B站千锋教育学习Python的第6天笔记,主要学习了字典的使用方法,包括字典的基本概念、访问、修改、添加、删除元素,以及获取字典信息、遍历字典和合并字典等内容。开学后时间有限,内容较为简略,敬请谅解。
|
10天前
|
存储 程序员 Python
Python学习的自我理解和想法(2)
今日学习Python第二天,重点掌握字符串操作。内容涵盖字符串介绍、切片、长度统计、子串计数、大小写转换及查找位置等。通过B站黑马程序员课程跟随老师实践,非原创代码,旨在巩固基础知识与技能。
|
9天前
|
程序员 Python
Python学习的自我理解和想法(3)
这是学习Python第三天的内容总结,主要围绕字符串操作展开,包括字符串的提取、分割、合并、替换、判断、编码及格式化输出等,通过B站黑马程序员课程跟随老师实践,非原创代码。
|
6天前
|
Python
Python学习的自我理解和想法(7)
学的是b站的课程(千锋教育),跟老师写程序,不是自创的代码! 今天是学Python的第七天,学的内容是集合。开学了,时间不多,写得不多,见谅。
|
4天前
|
存储 安全 索引
Python学习的自我理解和想法(8)
这是我在B站千锋教育学习Python的第8天,主要内容是元组。元组是一种不可变的序列数据类型,用于存储一组有序的元素。本文介绍了元组的基本操作,包括创建、访问、合并、切片、遍历等,并总结了元组的主要特点,如不可变性、有序性和可作为字典的键。由于开学时间紧张,内容较为简略,望见谅。
|
6天前
|
存储 索引 Python
Python学习的自我理解和想法(4)
今天是学习Python的第四天,主要学习了列表。列表是一种可变序列类型,可以存储任意类型的元素,支持索引和切片操作,并且有丰富的内置方法。主要内容包括列表的入门、关键要点、遍历、合并、判断元素是否存在、切片、添加和删除元素等。通过这些知识点,可以更好地理解和应用列表这一强大的数据结构。
|
6天前
|
索引 Python
Python学习的自我理解和想法(5)
这是我在B站千锋教育学习Python的第五天笔记,主要内容包括列表的操作,如排序(`sort()`、``sorted()``)、翻转(`reverse()`)、获取长度(`len()`)、最大最小值(`max()`、``min()``)、索引(`index()`)、嵌套列表和列表生成(`range`、列表生成式)。通过这些操作,可以更高效地处理数据。希望对大家有所帮助!
|
12天前
|
安全 程序员 Python
Python学习的自我理解和想法(1)
本篇博客记录了作者跟随B站“黑马程序员”课程学习Python的第一天心得,涵盖了`print()`、`input()`、`if...else`语句、三目运算符以及`for`和`while`循环的基础知识。通过实际编写代码,作者逐步理解并掌握了这些基本概念,为后续深入学习打下了良好基础。文中还特别强调了循环语句的重要性及其应用技巧。