详解pandas的外部数据导入与常用方法


Posted in Python onMay 01, 2019

外部数据导入

导入excel文件

pandas导入excel用read_excel()方法:

import pandas as pd


excel_file1 = pd.read_excel('data/测试.xlsx',encoding='utf-8')

姓名  年龄    工作    工资
0   张三  25    学生      200
1   李四  24    工人     3000
2   王伟  28    NaN      5000
3  王二毛  22  自由职业   6000

第一个参数是路径,既可以使用绝对路径又可以使用相对路径,如果文件名含有汉字,注意指定设置一下属性encoding = 'utf-8',另设置sheet_name指定具体的Sheet名字,也可传入sheet的顺序,从0开始。

excel_file1 = pd.read_excel('data/test.xlsx',sheet_name = 0)

指定索引

列索引默认从0开始,通过index_col设置,header设置行索引。

excel_file1 = pd.read_excel('data/测试.xlsx',encoding='utf-8',index_col=0)

年龄    工作    年资
姓名                
张三   25    学生      200
李四   24    工人     3000
王伟   28   NaN       5000
王二毛  22  自由职业   6000

excel_file1 = pd.read_excel('data/测试.xlsx',encoding='utf-8',header=1)

张三  25    学生     200
0   李四  24    工人    3000
1   王伟  28   NaN      5000
2  王二毛  22  自由职业  6000

指定索引列

有时本地文件列数太多,可以设置usercols指定导入的列,也可以列表形式传入多个值,表示传入哪些列。

excel_file1 = pd.read_excel('data/测试.xlsx',encoding='utf-8',usecols=[0,2])

姓名    工作
0   张三    学生
1   李四    工人
2   王伟    NaN
3  王二毛  自由职业

常用方法

  • shape() 可以获取excel文件的行和列,以元祖形式返回;
  • info() 获取数据类型;
  • astype() 可转换列里面的数据类型,括号里是要转换的目标类型;如 df[列2].astype('float64') ; df['列'].dtype 可查看列的类型
  • isnull() 判断哪个值是缺失值;
  • dropna() 删除有缺失值的行,返回删除后的数据,传入参数how=all,要全为空值才会删除;
  • fillna() 括号内可直接填入要要填充的值,也可指定列填充,以 字典 形式传参;
  • drop_duplicates() 默认对所有重复值判断,默认保留 keep=first 第一个行值;通过 keep 修改,值可为 last ,保留最后一个,还可设置 keep 为 False ,一个也不保留。另也可指定列名去重,如传入参数 subset =['列名1,列名2'],注意是以列表形式传参;
  • head() 传入的参数代表获取前几行;
  • describe() 掌握数值的分布情况,如均值,最值,方差,分位数。
  • column 和 index 可设置 列索引 和 行索引 ,以 列表 形式传参;
  • set_index() 重新设置索引列,传入要指名要用做行索引的名称;
  • reset_index(level = None,drop=False,inplace = False) ,level指定要将层次化索引的第几级别转化为 columns ,第一个索引为0级,第二个为1级,默认全部转化为columns。 drop 是否将原索引删掉, inplace 是否修改原数据表;该方法常用于数据分组和数据透视表中。
  • rename() 重命名索引,可重新设置 columns 和 index ,以 字典 形式传参, key 为原值, value 为替换后的值。

导入CSV文件

pandas导入csv文件用read_csv()方法;

import pandas as pd
csv_file1 = pd.read_csv('.\\data\\train-pivot.csv',index_col=0,header=0,nrows = 2)

通过 sep 设置分割符, encoding 指定编码格式。导入csv文件要指定为gbk,不然会报错,如果一个大文件你只需看前面几行,通过 nrows 设置。

import pandas as pd
csv_file1 = pd.read_csv('data/train-pivot.csv',encoding='gbk',nrows=2)
print(csv_file1)

用户ID 客户分类    区域 是否省会  7月销量  8月销量 
0  59224   A类  一线城市    是     6    20     0
1  55295   B类  三线城市    否    37    27    35

可以设置 usercols 指定导入的列。

用户ID    区域
0  59224  一线城市
1  55295  三线城市
2  46035  二线城市
3   2459  一线城市
4  22179  三线城市

导入sql

pandas中有 read_sql() 方法:

import pandas as pd
import pymysql
# 创建连接
conn = pymysql.connect(host = 'localhost',user = 'python',
            password = 'passwd',db = 'test',
            charset = 'utf-8'
            )
'''
user:用户名
password:密码
host:数据库地址/本机用localhost
db:数据库名
charset:编码,一般为utf-8
'''
sql = "SELECT * FROM user" # 写要执行的sql语句
pd.read_sql(sql,conn)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
深入解析Python中的WSGI接口
May 11 Python
Python文件去除注释的方法
May 25 Python
Python的Django框架中从url中捕捉文本的方法
Jul 20 Python
利用python代码写的12306订票代码
Dec 20 Python
简介Python的collections模块中defaultdict类型的用法
Jul 07 Python
python for循环输入一个矩阵的实例
Nov 14 Python
python+logging+yaml实现日志分割
Jul 22 Python
python有序查找算法 二分法实例解析
Feb 18 Python
python删除某个目录文件夹的方法
May 26 Python
python numpy库np.percentile用法说明
Jun 08 Python
Python Selenium异常处理的实例分析
Feb 28 Python
基于Python编写简易版的天天跑酷游戏的示例代码
Mar 23 Python
Python3.5文件读与写操作经典实例详解
May 01 #Python
Python3.5集合及其常见运算实例详解
May 01 #Python
Django给admin添加Action的步骤详解
May 01 #Python
Django重置migrations文件的方法步骤
May 01 #Python
OpenCV-Python 摄像头实时检测人脸代码实例
Apr 30 #Python
浅谈Python编程中3个常用的数据结构和算法
Apr 30 #Python
python通过paramiko复制远程文件及文件目录到本地
Apr 30 #Python
You might like
php curl获取网页内容(IPV6下超时)的解决办法
2013/07/16 PHP
PHP中call_user_func_array回调函数的用法示例
2016/11/26 PHP
PHP验证类的封装与使用方法详解
2019/01/10 PHP
理清apply(),call()的区别和关系
2011/08/14 Javascript
jquery插件制作 提示框插件实现代码
2012/08/17 Javascript
jQuery html()方法使用不了无法显示内容的问题
2014/08/06 Javascript
封装好的javascript前端分页插件pagination
2016/01/04 Javascript
Bootstrap模仿起筷首页效果
2016/05/09 Javascript
jQuery height()、innerHeight()、outerHeight()函数的区别详解
2016/05/23 Javascript
JS检测移动端横竖屏的代码
2016/05/30 Javascript
Augularjs-起步详解
2016/07/08 Javascript
浅谈jQuery添加的HTML,JS失效的问题
2016/10/05 Javascript
JavaScript的兼容性与调试技巧
2016/11/22 Javascript
浅析location.href跨窗口调用函数
2016/11/22 Javascript
JavaScript使用正则表达式获取全部分组内容的方法示例
2017/01/17 Javascript
使用Phantomjs和Node完成网页的截屏快照的方法
2019/07/16 Javascript
[51:14]LGD vs VP 2018国际邀请赛淘汰赛BO3 第一场 8.21
2018/08/22 DOTA
PYTHON正则表达式 re模块使用说明
2011/05/19 Python
python实现自动更换ip的方法
2015/05/05 Python
TensorFlow用expand_dim()来增加维度的方法
2018/07/26 Python
python实现微信每日一句自动发送给喜欢的人
2019/04/29 Python
python3反转字符串的3种方法(小结)
2019/11/07 Python
Pytest参数化parametrize使用代码实例
2020/02/22 Python
HTML5 canvas基本绘图之绘制矩形
2016/06/27 HTML / CSS
瑞典轮胎在线:Tirendo.se
2018/06/21 全球购物
super()与this()的区别
2016/01/17 面试题
安全员岗位职责
2013/11/11 职场文书
绩效工资分配方案
2014/01/18 职场文书
大学生党员承诺书
2014/05/20 职场文书
公司股东合作协议书
2014/09/14 职场文书
期末考试复习计划
2015/01/19 职场文书
悬空寺导游词
2015/02/05 职场文书
保管员岗位职责
2015/02/14 职场文书
盗窃案辩护词
2015/05/21 职场文书
2015年骨干教师工作总结
2015/05/26 职场文书
2016年幼儿园万圣节活动总结
2016/04/05 职场文书