pandas模块之读取文件
首先我们来看一个文件
1 男 北京 刘一 我笑
#跳过此行,序号1
2 女 上海 刘珊 你笑
3 男 杭州 刘五 他笑
#跳过此行,序号四
4 女 重庆 刘六 不笑了
下面来分析内容,并使用参数
1 第一眼:排列很乱,空格有的多有的少 --》sep='\s+' 用正则去匹配 2 没用标题 ---》names=["序号","性别","城市","名字"] 3 最后一列看着不雅观,不要,选定我们需要的 --》usecols=[0,1,2,3] 4 还有注释这不是坑爹吗 ---》skiprows=[1,4] 5 我们最后来指定一个索引 ---》index_col='名字'
data=pd.read_csv('pandasfile.txt',names=["序号","性别","城市","名字"],index_col='名字',skiprows=[1,4],usecols=[0,1,2,3],sep="\s+")
print(data)
下面是结果
序号 性别 城市
名字
刘一 1 男 北京
刘珊 2 女 上海
刘五 3 男 杭州
刘六 4 女 重庆
其他
pandas.read_csv()
从文件,URL,文件型对象中加载带分隔符的数据。默认分隔符为'',"
pandas.read_table()
从文件,URL,文件型对象中加载带分隔符的数据。默认分隔符为"\t" 如果要指定的列太多,怎么办,去除上面的usecols,另敲一个命令:data.iloc[:,0:3] 命令ix已经被替代,以后不使用
操作:
选取性别==女的行
print(data.loc[data['性别']=='女'])
选取城市是北京 和上海 的行,以及 取反(名称伴终生啊)
print(data.loc[data['城市'].isin(['北京','上海'])]) 结果:
序号 性别 城市 其他
名字
刘一 1 男 北京 我笑
刘珊 2 女 上海 你笑 -------------------------取反--------------------------------------------
print(data.loc[~data['城市'].isin(['北京','上海'])])
结果:
序号 性别 城市 其他
名字
刘五 3 男 杭州 他笑
刘六 4 女 重庆 不笑了
使用replace替换单个或者多个
1 替换单个
kk=data['其他'].replace('我笑','哭')
print(kk)
结果
名字
刘一 我笑
刘珊 哭
刘五 他笑
刘六 不笑了
Name: 其他, dtype: object 2 使用正则匹配多个替换
kk=data['其他'].replace('.*笑','哭',regex=True)
print(kk)
结果:
名字
刘一 哭
刘珊 哭
刘五 哭
刘六 哭了
Name: 其他, dtype: object
替换多个列的情况,我们最后加一列,我们发现:索引不会被替换
data的值
序号 性别 城市 其他
名字
刘一 1 男 北京 我笑
刘珊 2 女 上海 你笑
刘五 3 男 杭州 他笑
刘六 4 女 重庆 不笑了
刘笑 5 女 苏笑 呵呵 print(data.replace('笑','哭',regex=True)) #不加regex的话,data的值不会变化,必须要具体的值,例如:data.replace('苏笑','哭') 结果:
序号 性别 城市 其他
名字
刘一 1 男 北京 我哭
刘珊 2 女 上海 你哭
刘五 3 男 杭州 他哭
刘六 4 女 重庆 不哭了
刘笑 5 女 苏哭 呵呵
最后,经过上面的一大堆操作,data的数据还是不会变,要让它变怎么处理
inplace=True
一个很魔性的功能,写入剪贴板
data.to_clipboard() #直接就可以在其他地方黏贴了
写入文件:经过测试:sep使用\s+报错,使用‘ ’和‘\t’都不是我们要的结果,主要文件打开状态使用此命令:报权限错误
data.to_csv('D:\\a.csv',sep=',',header=True,index=True) #它的索引还是会写在最前面
sep:字段分隔符
header:是否需要头部
index:是否需要行号

其他参数:
path:表示文件系统位置、URL、文件型对象的字符串。
sep或delimiter:用于对行中各字段进行拆分的字符序列或正则表达式。
header:用作列名的行号。默认为0(第一行),如果文件没有标题行就将header参数设置为None。
index_col:用作行索引的列编号或列名。可以是单个名称/数字或有多个名称/数字组成的列表(层次化索引)。
names:用于结果的列名列表,结合header=None,可以通过names来设置标题行。
skiprows:需要忽略的行数(从0开始),设置的行数将不会进行读取。
na_values:设置需要将值替换成NA的值。
comment:用于注释信息从行尾拆分出去的字符(一个或多个)。
parse_dates:尝试将数据解析为日期,默认为False。如果为True,则尝试解析所有列。除此之外,参数可以指定需要解析的一组列号或列名。如果列表的元素为列表或元组,就会将多个列组合到一起再进行日期解析工作。
keep_date_col:如果连接多列解析日期,则保持参与连接的列。默认为False。
converters:由列号/列名跟函数之间的映射关系组成的字典。如,{"age:",f}会对列索引为age列的所有值应用函数f。
dayfirst:当解析有歧义的日期时,将其看做国际格式(例如,7/6/2012 ---> June 7 , 2012)。默认为False。
date_parser:用于解析日期的函数。
nrows:需要读取的行数。
iterator:返回一个TextParser以便逐块读取文件。
chunksize:文件块的大小(用于迭代)。
skip_footer:需要忽略的行数(从文件末尾开始计算)。
verbose:打印各种解析器输出信息,如“非数值列中的缺失值的数量”等。
encoding:用于unicode的文本编码格式。例如,"utf-8"或"gbk"等文本的编码格式。
squeeze:如果数据经过解析之后只有一列的时候,返回Series。
thousands:千分位分隔符,如","或"."。
pandas模块之读取文件的更多相关文章
- 1.pandas打开和读取文件
最近在公司在弄数据分析相关的项目,数据分析就免不了要先对数据进行处理,也就自然避不开关于excel文档的初始化操作了. 一段时间之后,发现pandas更加符合我的项目要求,所以,将一些常规操作记录下来 ...
- pandas.read_csv()函数读取文件时,关于“header=None”影响读取列数区间的右闭合总结
对于一个没有字段名标题的数据,如data.csv 1.获取数据内容.pandas.read_csv("data.csv")默认情况下,会把数据内容的第一行默认为字段名标题. imp ...
- [Python]-pandas模块-CSV文件读写
Pandas 即Python Data Analysis Library,是为了解决数据分析而创建的第三方工具,它不仅提供了丰富的数据模型,而且支持多种文件格式处理,包括CSV.HDF5.HTML 等 ...
- Pandas读取文件
如何使用pandas的read_csv模块以及其他读取文件的模块?? 一起来看一看 Pandas中read_csv和read_table的区别 注:使用pandas读取文件格式为pandas特有的da ...
- [Python]-pandas模块-机器学习Python入门《Python机器学习手册》-02-加载数据:加载文件
<Python机器学习手册--从数据预处理到深度学习> 这本书类似于工具书或者字典,对于python具体代码的调用和使用场景写的很清楚,感觉虽然是工具书,但是对照着做一遍应该可以对机器学习 ...
- python linecache模块读取文件的方法
转自: python linecache模块读取文件 在Python中,有个好用的模块linecache,该模块允许从任何文件里得到任何的行,并且使用缓存进行优化,常见的情况是从单个文件读取多行. l ...
- 【Python】 linecache模块读取文件
[linecache] 过往在读取文件的时候,我们通常使用的是这种模式: with open('file.txt','r') as f: line = f.readline() while line: ...
- nodejs读取文件时相对路径的正确写法(使用fs模块)
在开发nodejs中,我们往往需要读取文件或者写入文件,最常用的模块就是fs核心模块.一个最简单的写入文件的代码如下(暂时不考虑回调函数): fs.readFile("./test.txt& ...
- python linecache模块读取文件用法详解
linecache模块允许从任何文件里得到任何的行,并且使用缓存进行优化,常见的情况是从单个文件读取多行. linecache.getlines(filename) 从名为filename的文件中得到 ...
随机推荐
- 【HDOJ6664】Andy and Maze(color coding)
题意:给定一张n点m边的无向带权图,问从任意结点出发,不能走已经经过的点,共经过k个点的最长路径的值 n,m<=1e4,k<=6 思路:color coding算法 考虑每次给每个点随机编 ...
- 【2019 Multi-University Training Contest 7】
01:https://www.cnblogs.com/myx12345/p/11653845.html 02: 03: 04: 05: 06:https://www.cnblogs.com/myx12 ...
- 阿里云code下载代码和更新代码
1- 本地新建一个文件夹,进入文件夹下面右击打开git 2- Git init初始化一个.git文件夹 3- Git clone git@code.aliyun.com:username/space- ...
- php面试专题---MySQL分区
php面试专题---MySQL分区 一.总结 一句话总结: mysql的分区操作还比较简单,好处是也不用自己动手建表进行分区,和水平分表有点像 1.mysql分区简介? 一个表或索引-->N个物 ...
- 关于ADB 执行报错问题-db server version (31) doesn't match this client (40); killing...
D:\ADB>adb devicesList of devices attachedadb server version (31) doesn't match this client (40); ...
- Python分析《武林外传》
我一向比较喜欢看武侠电影.小说,但是06年武林外传开播的时候并没有追剧,简单扫几眼之后发现他们都不会那种飞来飞去的打,一点也不刺激.09年在南京培训的时候,日子简单无聊透顶,大好的周末不能出门,只能窝 ...
- 大数据学习笔记之Zookeeper(四):Zookeeper实战篇(二)
文章目录 4.1 分布式安装部署 4.2 客户端命令行操作 4.3 API应用 4.3.1 eclipse环境搭建 4.3.2 创建ZooKeeper客户端: 4.3.3 创建子节点 4.3.4 获取 ...
- Linux 命令详解 - ps
完整文档 ps 命令用于显示命令执行瞬间的进程状态(Process Status).如果想动态查看进程状态可以使用 top 命令. 进程的概念 进程类型 前台进程:由终端初始化,可以通过命令行进行交互 ...
- Nginx 在各种语言框架下的配置 - 以 codeigniter 为例
对于各种语言常用的框架,Nginx 在官方的 Wiki 页面的 入门 部分提供了示例配置文件.具体可以参考这个页面的 Pre-canned Configurations 部分,这里列出了各种框架. 直 ...
- SAT算法
今早用微云打的笔记...头大 我惊,这不是可爱的离散吗?! 建个有向图G,(Xi+Yi)加两边表示( ¬Xi+Yi)(Xi+ ¬Yi) 每个点(eg:A)加上 ¬A 下图为:(A->B)·( ¬ ...