一、seek(参数1,参数2)
作用:能够将指针移动指定的偏移量
参数1:移动的偏移量,默认为0
参数2: 0:将指针移动到文件开头、1(默认):指针指向当前位置、2:指针移动到文件尾部
通过例子我们来具体应用:
1.首先打开一个文本文件
以我自己打开的文本文件为例子:
f1 = open('界面.txt', 'r', encoding='utf-8')
print(f1.read())
显示的结果为:
2.将指针再移动到文件开头
f1.seek(0,0)
print(f1.read())
一个英文符号对应一个偏移量,一个汉字和一个中文符号对应3个偏移量
python中有序序列(容器)下标从0开始
python操作文件时的偏移量从1开始
比如:
f1.seek(6, 0)
print(f1.read())
显示结果为:
上面程序表示:将指针移动到文件开头,再增加6个偏移量(表示从第六个偏移量之后开始)
二、tell()
表示:查看当前指针的位置
从第一个字开始到最后一个字
比如:
f1 = open('界面.txt', 'r', encoding='utf-8')
print(f1.tell())
显示结果为:
206
在此处中文和中文符号也相当于三个英文或者英文符号
可以自己将字符数量算出来对比
换行
如果自己算出来的结果小于使用tell()的结果,可能是系统问题
一般来说:
linux:\n
windows:\r\n
mac:\r
tell()中算上了每换一行的一个字符
二、CSV文件读写
CSV文件本质是文本文件,只是以表格的形式显示数据
我们要使用CSV内置模块进行csv文件的读写操作
import csv
(一)CSV文件写操作
1.返回一个文件对象
Windows或者Linux操作系统,写CSV文件必须加newline=‘’
newline = ‘’ —>将换行转为空
假设我现在打开一个文件:
f1 = open('./店铺信息.csv', 'w', encoding='utf-8', newline='')
print(f1)
2.创建写方法对象
mywrite = csv.writer(f1)
3.写入列名
单行写入:writerow()
col = ['店铺名', '人均', '口味', '环境', '服务']
mywrite.writerow(col)
4.写入对应信息
多行写入:writerows()
datas = [
['哄堂老火锅', 126, 4.5, 4.7, 4.6],
['小龙坎', 100, 4.8, '4.8', 4.7],
['巴蜀大宅门', '70', '4.8', '4.6', 4.8]
]
mywrite.writerows(datas)
数字用不用字符串写都可以,都会转化成字符串
一定要记得写入之后关闭文件!
(二)CSV文件读操作
先打开文件
f2 = open('./店铺信息.csv', 'r', encoding='utf-8')
创建读方法
myreader = csv.reader(f2)
for i in myreader:
print(i)
for j in i:
print('{:<8}'.format(j), end='')
# 这里的print()表示换行
print()
(三)如何用excel打开CSV
打开excel,按照以下步骤点击
数据 —— 获取数据 —— 自文件 —— 从文本/CSV —— 在文件管理器中找CSV文件 ——修改文件原始格式(UTF-8) ——点击右下角 加载 —> 点击工具栏转换为区域
具体图示: