Python中seek、tell方法,CSV文件读写操作以及如何用Excel打开CSV

一、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) ——点击右下角 加载 —> 点击工具栏转换为区域

具体图示:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值