目录
- 文件操作
- 文件读写模式
- 文件操作模式
- 文件诸多方法
- 文件内光标的移动
- 文件内光标移动案例(了解)
- 计算机硬盘修改数据的原理(了解)
- 文件内容修改(了解)
- 函数前戏
- 函数的语法结构
- 函数的定义与调用
- 函数的分类
- 函数的返回值
- 函数的参数
文件操作
1. 文件的概念
就是操作系统暴露给用户操作硬盘的快捷方式
例如:双击一个文件,就是从硬盘将数据加载到内存
ctrl+s 保存文件,其实就是将内存中的数据刷到硬盘保存
2. 代码打开文件的两种方式
方式1:
f=open(文件路径,读写模式,encoding='utf8')
f.close()
方式2:
with open('a.txt','r',encoding='utf8') as f1:
with子代码块
ps:with上下文管理好处在于子代码运行结束自动调用close方法关闭资源
"""
open方法的一个参数是文件路径 并且撬棍跟一些字母的组合会产生特殊的含义导致路径查找混乱,为了解决该问题可以在字符串的路径前面加字母r
D:\a\n\t r'D:\a\n\t'
以后涉及到路径的编写,推荐加上r
with支持一次性打开多个文件
with open() as f1,open() as f2,open() as f3:
子代码
"""
f = open('a.txt','r', encoding='utf8')
print(f.read())
f.close()
with open(r'a.txt', 'r', encoding='utf8') as f1:
print(f1.read())
with open(r'D:\bb\cc\b.txt.txt', 'r', encoding='utf8') as f1:
print(f1.read())
with open(r'a.txt','r',encoding='utf8') as f1,open(r'D:\bb\cc\b.txt.txt','r',encoding='utf8') as f2:
print(f1.read())
print(f2.read())
文件读写模式
'r' 只读模式,只能读不能写
# 1. 文件路径不存在,会直接报错
with open(r'bb.txt','r',encoding='utf8') as f:
print(f.read())
# 2. 文件路径存在:正常读取文件内容
with open(r'a.txt','r',encoding='utf8') as f:
print(f.read())
'w' 只写模式:只能写不能看
# 1.文件路径不存在:自动创建
with open(r'bb.txt','w',encoding='utf8') as f:
pass
# 2. 文件路径存在:先清空文件内容 之后再写入
with open(r'a.txt','w',encoding='utf8') as f:
f.write('假期综合征,赶紧要调整\n')
f.write('假期综合征,赶紧要调整\n')
f.write('假期综合征,赶紧要调整\n')
"""强调:换行符需要自己添加 并且在后续数据读取对比的时候也一定要注意它的存在"""
'a' 只追加模式:文件末尾添加数据
# 1.文件路径不存在: 自动创建
with open(r'c.txt','a',encoding='utf8') as f:
pass
# 2. 文件路径存在:自动在末尾等待追加内容
with open(r'a.txt','a',encoding='utf8') as f:
f.write('放假7天和上班7天感觉是完全不一样的')
"""
当我们在编写代码的时候 有些部分不知道写什么具体代码,但是也不能空着不写
这时候可以使用关键字
pass 或者三个点...
只补全语法不执行功能 本身没有任何的含义
"""
文件操作模式
t 文本模式
默认的模式,我们上面写的r w a其实全称是rt wt at
1. 只能操作文本文件
2. 读写都是以字符为单位
3. 需要指定encoding参数 如果不知道则会采用计算机默认的编码
b 二进制模式(bytes模式)
不是默认的模式 需要自己指定rb wb ab
1. 可以操作任意类型的文件
2. 读写都是以bytes为单位
3. 不需要指定encoding参数,因为它已经是二进制模式了,不需要编码
二进制模式与文本模式对文件路径是否存在的情况下 规律是一样的!!!
with open(r'a.txt','rb') as f:
print(f.read().decode('utf8'))
with open(r'c.txt','wb') as f:
f.write('哈哈哈 天黑了'.encode('utf8'))
f.write(b'hello world 666') # 如果字符串中只有英文和数字,没有其它国家的字符,那么编码可以简化,字符串前面直接加字母b即可
f.write('hello world 666'.encode('utf8'))
with open(r'c.txt','rb') as f:
data = f.read()
print(data.decode('utf8'))
# 编码解码其它方法
res = '天黑了 要干饭了'
data = bytes(res,'utf8') # encode()
ret = str(data,'utf8') # decode()
print(ret) # 天黑了 要干饭了
文件诸多方法
1. read()
一次性读取文件内容 并且光标停留在文件末尾 继续读取则没有内容
并且当文件内容较多的时候 该方法可能会造成计算机内存溢出
括号内还可以填写数字 在文本模式下 表示读取几个字符
2. for循环
一行行读取文件内容 避免内存溢出现象的产生
3. readline()
一次只读一行内容
4. readlines()
一次性读取文件内容 会按照行数组织成列表的一个个数据值
5. readable()
判断文件是否具备读数据的能力
6. write()
写入数据
7. writeable()
判断文件是否具备写数据的能力
8. writelines()
接收一个列表一次性将列表中所有的数据值写入
9. flush()
将内存中文件数据立刻刷到硬盘 等价于ctrl + s
with open(r'c.txt','r',encoding='utf8') as f:
print(f.read(10))
with open(r'c.txt','r',encoding='utf8') as f:
print('读取文件中所有的内容>>>:', f.read())
print('读取文件中所有的内容>>>:', f.read())
print('读取文件中所有的内容>>>:', f.read())
with open(r'c.txt','r',encoding='utf8') as f:
# 当文件内容较多的时候 可以使用for循环一行行读取
for line in f:
print(line)
print('+++++++++++')
with open(r'c.txt','r',encoding='utf8') as f:
print(f.readline())
print(f.readline())
print(f.readline())
with open(r'c.txt','r',encoding='utf8') as f:
print(f.readlines())
with open(r'c.txt','r',encoding='utf8') as f:
print(f.readable())
with open(r'c.txt','w',encoding='utf8') as f:
print(f.writable())
with open(r'c.txt','w',encoding='utf8') as f:
f.writelines(['嘿嘿嘿\n','哈哈哈\n','呵呵呵\n'])
with open(r'c.txt','w',encoding='utf8') as f:
f.flush()
文件内光标的移动
with open(r'a.txt','r',encoding='utf8') as f:
print(f.read(3)) # 文本模式下 3 是字符的意思
print(f.read(3))
with open(r'a.txt','rb') as f:
print(f.read(5).decode('utf8')) # 二进制模式下 3是字节的意思,三个字节等于一个汉字,默认按字节来取
print(f.read(3).decode('utf8'))
with open(r'a.txt','rb') as f:
print(f.read())
f.seek(0,0)
print(f.read())
f.seek(0,0)
print(f.read())
# print(f.read(2).decode('utf8'))
# f.seek(-1,2)
# print(f.tell()) # 返回光标距离文件开头产生的字节数
"""
seek(offset, whence)
offset是位移量 以字节为单位
whence是模式 0 1 2
0 是基于文件开头,文本和二进制模式都可以使用
1 是基于当前位置 只有二进制模式可以使用
2 是基于文件末尾 只有二进制模式可以使用
"""
文件内光标移动案例(了解)
import time
with open(r'a.txt','rb') as f:
f.seek(0, 2)
while True:
line = f.readline()
if len(line) == 0:
# 没有内容
time.sleep(0.5)
else:
print(line.decode('utf8'),end='')
计算机硬盘修改数据的原理(了解)
硬盘写数据可以看成是在硬盘上刻字 一旦需要修改中间内容 则需要重新刻字
因为刻过的字不可能从中间再分开
硬盘删除数据原理
不是直接删除而是改变状态 等待后续数据的覆盖才会被真正删除
文件内容修改(了解)
# 修改文件内容的方式1:覆盖写
with open(r'a.txt','r', encoding='utf8') as f:
data = f.read()
with open(r'a.txt','w', encoding='utf8') as f1:
f1.write(data.replace('jason','tony'))
# 修改文件内容的方式2: 换地方写
""" 先在另外一个地方写入内容 然后将源文件删除 将新文件重命名成源文件"""
import os
with open('a.txt', 'r', encoding='utf8') as read_f, open('.a.txt.swap','w',encoding='utf8')as write_f:
for line in read_f:
write_f.write(line.replace('tony','kevinSB'))
os.remove('a.txt')
os.rename('.a.txt.swap','a.txt')
函数前戏
name_list = ['jason', 'kevin', 'oscar', 'jerry']
# print(len(len(name_list)))
'''突然len不准用了'''
count = 0
for i in name_list:
count += 1
print(count)
'''统计列表内数据值个数的代码需要在很多地方使用'''
# 相同的代码需要在不同的位置反复执行
"""
循环
相同的代码在相同的位置反复执行
函数
相同的代码在不同的位置反复执行
ps:相同的代码不是真正一模一样 而是可以通过传入的数据不同而做出不同的改变
"""
def my_len():
count = 0
for i in name_list:
count += 1
print(count)
my_len()
"""
函数相当于工具(具有一定功能)
不用函数
修理工需要修理器件要用锤子 原地打造 每次用完就扔 下次用继续原地打造
用函数
修改工提前准备好工具 什么时候想用就直接拿出来使用
"""
函数的语法结构
def 函数名(参数):
'''函数注释'''
函数体代码
return 返回值
1.def 定义函数的关键字
2.函数名 命名等于变量名
3.参数 可有可无 主要是在使用函数的时候规定要不要外界传数据进来
4.函数注释 类似于工具说明书
5.函数体代码 是整个函数的核心 主要取决于程序员的编写
6. return 使用函数之后可以返回给使用者的数据 可有可无
函数的定义与调用
1.函数在定义阶段只检测语法 不执行代码
def func():
pass
2.函数在调用阶段才会执行函数体代码
func()
3.函数必须先定义后调用
4.函数定义使用关键字def函数调用使用>>>:函数名加括号
如果有参数则需要在括号内按照相应的规则传递参数(后续详细讲解)
函数的分类
1. 空函数
函数体代码为空 使用pass或者...补全
空函数主要用于项目前期的功能框架搭建
def register():
"""注册功能"""
pass
2.无参函数
定义函数的时候括号内没有参数
def index():
print('from index function')
3.有参函数
定义函数的时候括号内写参数 调用函数的时候括号传参数
def func(a):
print(a)
函数的返回值
1.什么是返回值
调用函数之后返回给调用者的结果
2.如何获取返回值
变量名 赋值符号 函数的调用
res = func() # 先执行func函数 然后将返回值赋值给变量res
3.函数返回值的多种情况
3.1 函数体代码中没有return关键字 默认返回None
3.2 函数体代码有return 如果后面没有写任何东西还是返回None
3.3 函数体代码有return 后面写什么就返回什么
3.4 函数体代码有return并且后面有多个数据值 则自动组织成元组返回
3.5 函数体代码遇到return会立刻结束
函数的参数
形式参数
在函数定义阶段括号内填写的参数 简称'形参'
实际参数
在函数调用阶段括号内填写的参数 简称'实参'
++++++++++++++++++++++++++++++++++++++++
"""
形参与实参的关系
形参类似于变量名 在函数定义阶段可以随便写 最好见名知意
def register(name,pwd):
pass
实参类似于数据值 在函数调用阶段与形参临时绑定 函数运行结束立刻断开
register('jason',123) 形参name与jason绑定 形参pwd与123绑定
"""
++++++++++++++++++++++++++++++++++++++++
标签:文件,函数,encoding,utf8,初识,print,txt,open
From: https://www.cnblogs.com/winter-yu1989/p/16773011.html