没有合适的资源?快使用搜索试试~ 我知道了~
python中读入二维csv格式的表格方法详解(以元组/列表形式表示)
3 下载量 188 浏览量
2020-12-20
11:08:51
上传
评论
收藏 49KB PDF 举报
温馨提示
试读
1页
如何去读取一个没有表头的二维csv文件(如下图所示)? 并以元组的形式表现数据: ((1.0, 0.0, 3.0, 180.0), (2.0, 0.0, 2.0, 180.0), (3.0, 0.0, 1.0, 180.0), (4.0, 0.0, 0.0, 180.0), (5.0, 0.0, 3.0, 178.0)) 方法一,使用python内建的数据处理库: #python自带的库 rows = open('allnodes.csv','r',encoding='utf-8').readlines() lines = [x.rstrip() for x in rows]#去掉每行
资源推荐
资源详情
资源评论
python中读入二维中读入二维csv格式的表格方法详解格式的表格方法详解(以元组以元组/列表形式列表形式
表示表示)
如何去读取一个没有表头的二维csv文件(如下图所示)?
并以元组的形式表现数据:
((1.0, 0.0, 3.0, 180.0), (2.0, 0.0, 2.0, 180.0), (3.0, 0.0, 1.0, 180.0), (4.0, 0.0, 0.0, 180.0), (5.0, 0.0, 3.0, 178.0))
方法一,使用方法一,使用python内建的数据处理库:内建的数据处理库:
#python自带的库
rows = open('allnodes.csv','r',encoding='utf-8').readlines()
lines = [x.rstrip() for x in rows]#去掉每行数据的/n转义字符
lines[0] = '1,0,3,180'#手动去掉第一行的csv开始符号
data = []#使用列表读取是因为列表长度是可变的,而元组不可。
[data.append(eval(i)) for i in lines]#将每一行数据以子列表的形式加入到data中
allnodes = tuple(data)#将列表类型转化为元组,若想用二维列表的形式读取即删掉此行语句
print(allnodes)
out:((1, 0, 3, 180), (2, 0, 2, 180), (3, 0, 1, 180), (4, 0, 0, 180), (5, 0, 3, 178), (6, 0, 2, 178), (7, 0, 1, 178), (8, 0, 0,
178),…,(29484, -40, 0, 0))
方法二,使用方法二,使用pandas库:库:
import pandas as pd
df = pd.read_csv('allnodes.csv',header = None)#因为没有表头,不把第一行作为每一列的索引
data = [] for i in df.index:
data.append(tuple(df.values[i]))
allnodes = tuple(data)#若想用二维列表的形式读取即删掉此行语句
print(allnodes)
out:
((1.0, 0.0, 3.0, 180.0), (2.0, 0.0, 2.0, 180.0), (3.0, 0.0, 1.0, 180.0), (4.0, 0.0, 0.0, 180.0), (5.0, 0.0, 3.0, 178.0), (6.0, 0.0, 2.0, 178.0), (7.0, 0.0, 1.0, 178.0),
(8.0, 0.0, 0.0, 178.0),..., (29484.0, -40.0, 0.0, 0.0))
小结:用python自带的库进行读取的时候可能稍快,但对于大型的多维数据处理,使用pandas可进行更方面,灵活,可视化
的操作。
您可能感兴趣的文章您可能感兴趣的文章:python读写csv文件方法详细总结python读csv文件时指定行为表头或无表头的方法Python将列表数据写
入文件(txt, csv,excel)Python把对应格式的csv文件转换成字典类型存储脚本的方法Python读取csv文件分隔符设置方法
资源评论
weixin_38694566
- 粉丝: 5
- 资源: 878
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功