大数据技术技能分析大赛——第二章 数据的导入和导出
2.1导入数据
1、导入excel表格数据
Excel有两种格式,分别为xls和xlsx格式,两种都可以用python的Pandas模块的read_excel方法导入。read_excel方法返回的结果是DataFrame,DataFrame的一列对应着Excel的一列
read_excel方法参数介绍:
(1)sheet_name参数:该参数用于指定导入Excel中的哪一个sheet,如果不填写这个参数,则默认导入第一个sheet
(2)index_col参数:该参数用于指定表格的哪一列作为DataFrame的行索引。从0开始计数
(3)nrows参数:该参数可以控制导入的行数,该参数在导入文件体积较大时比较有用
(4)skipfooter参数:该参数可以在导入数据时,跳过表格底部的若干行
(5)header参数:当使用Pandas的read_excel方法导入Excel文件时,默认表格的第一行为字段名。如果表格的第一行不是字段名。则需要使用该参数设置字段名
(6)usecols参数:该参数可以控制导入Excel表格中的哪些列
(7)names参数:该参数可以对导入数据的列名进行重命名
import pandas as pd# 导入pandas模块并将其缩写
df=pd.read_excel("C:/Users/kzk/Desktop/背景介绍.xlsx")#使用该方法导入数据
df
括号里为本地表格地址,可以通过查看属性进行获取,注意地址的分隔符时反斜杠
df1=pd.read_excel("C:/Users/kzk/Desktop/背景介绍.xlsx",index_col=0)
df1
#取消行索引
df2=pd.read_excel("C:/Users/kzk/Desktop/背景介绍.xlsx",nrows=5)
df2
#导入前五行
df3=pd.read_excel("C:/Users/kzk/Desktop/背景介绍.xlsx",header=None)
df3
#取消表格第一行为默认表头,以0123···为表头
df4=pd.read_excel("C:/Users/kzk/Desktop/背景介绍.xlsx",header=None,name=['A','B','C','D','E'])
df4
#取消表格第一行为默认表头,以ABCDE为表头
df5=pd.read_excel("",header=None,names={'A','B','C','D','E'},usecols=[1,3])
df5
#索引为1和3,也就是第二列和第四列
2、导入CSV格式数据
read_csv方法中的sep参数表示要导入的csv文件的分隔符,默认是半角逗号。encoding参数用来指定CSV文件的编码,常用的有utf-8h和gbk
import pandas as pd
df1=pd.read_csv("",sep=",",encoding="gbk")
df1
df2=pd.read_csv("",sep=",",encoding="gbk",nrows=3)
df2
#只导入前三行
df4=pd.read_csv("",sep=",",encoding="gbk",names=["ID","fruit","amount"])
df4
3、导入JSON数据
JSON数据是一种轻量级的数据交换格式,容易阅读,也容易被机器扫描,在互联网应用中很常见,有时候从后台系统中导出来的数据就是JSON格式
JSON文件实际上存储的是一个JSON对象或者一个JSON数组,JSON对象是由多个键值对组成的,类似python的字典,JSON数组由多个JSON对象组成,类似列表
import pandas as pd
json=pd.read_json("路径")
json
4、导入txt格式数据
使用read_table方法,参数和用法与read_csv类似
import pandas as pd
df1=pd.read_table("路径")
df1
5、导入(爬取)网络数据
在数据分析中,除了可以导入文件和数据库中的数据,还有一类非常重要的数据就是网络数据,网络中每天都会产生大量数据,这些数据具有实时性,种类丰富的特点,因此对于数据分析而言是十分重要的一类数据来源
关键技术:爬取网络表格类数据,pandsa库read_html()方法
read_html()方法用于导入带有table标签的网页表格数据,使用该方法前,首先要确定网页表格数据是否为table标签。右击网页中的表格查看元素
确定后才可以使用read_html的方法
常用参数说明如下
io:字符串,文件路径,也可以是URL连接,网址不接受https,可以尝试去掉s后爬取
header:指定列标题所在的行
index_col:指定列标题所在的行
index_col:指定行标题对应的列
【例】 爬取A股公司营业收入排行榜
中商情报网是专业的产业情报分享云平台,主要提供研究报告、行业分析、市场调研等数据。在本案例中,通过爬取中商情报网中A股公司营业收入排行榜表格获取相应的金融数据,数据网址为https://s.askci.com/stock/a/
import pandas as pd
url="https://s.askci.com/stock/a/"
df=pd.read_html(url)[0]#索引为0
print(df)
0 1 2 3
0 排名 股票代码 企业简称 营业收入(亿元)
1 1 600028 中国石化 27408.84
2 2 601857 中国石油 26143.49
3 3 601668 中国建筑 18913.39
4 4 601318 中国平安 11804.44
5 5 601390 中国中铁 10704.17
6 6 601186 中国铁建 10200.10
7 7 601398 工商银行 9427.62
8 8 601628 中国人寿 8585.05
9 9 600941 中国移动 8482.58
10 10 601939 建设银行 8242.46
2.2输出数据
1、CSV格式数据输出
【例】导入sales.csv文件中的前10行数据,并将其导出为sales_new.csv文件
关键技术:pandas库中的to_csv方法
在该例中,首先通过pandas库的read_casv方法导入sales.csv文件的前十行数据,然后使用pandas库的to_csv方法将导出的数据输出为sales_new.csv文件
import pandas as pd
df=pd.read_csv("地址",sep=","encoding="gbk",nrows=10)
df.to_csv('sales_new.csv',encoding="gbk")
pandas库的to_csv方法,参数说明:
path_or_buf:要保存的路径及文件名
sep:分割符,默认为","
columns:指定要输出的列,用列名,列表表示,默认值为None
header:是否输出列名,默认值为True
index:是否输出索引,默认值为True
encoding:编码方式,默认值为"utf-8" 也可以是gbk
【例】对于上一小节中的问日,如销售文件格式为:sales.xlsx文件,如何处理
关键技术:DataFrame对象的to_excel方法
与上例相似,该例首先利用Pandas库的read_excel方法读入sales.xlsx文件,然后使用to_excel方法导出新文件
import pandas as pd
df=pd.read_excel("地址")
df1=df.head(10)
df1.to_excel('sales_new.xlsx',encoding="gbk")
2、xlsx格式数据输出
对于Pandas库中的to_excel()方法,有下列参数说明
sheet_name:字符串,默认值为"sheet1",指包含DataFrame数据的表的名称
np_rep:字符串,默认值为’'。指缺失数据的表示方式
columes:序列,可选参数,要编辑的列
header:布尔型或字符串列表,默认值为True。如果给定字符串列表,则表示它是列名称的别名
index:布尔型,默认值为True 行名(索引)
index_label:字符串型或序列,默认值为None。如果文件数据过多的使用多索引,则需使用序列
encoding:指定Excel文件的编码方式,默认值为None
3、导入到多个sheet页中
【例】将sale.xlsx文件中的前十行数据,导出到sales_new.xlsx文件中名为df1的sheet页中将后五行数据导出到名为df2的sheet页中
首先建立df1/df2sheet页,然后使用pd.ExcelWriter方法打开sales_new.xlsx文件,再用to_excel方法导入到指定的sheet页中
import pandas as pd
df=pd.read_excel("地址")
df1=df.head(10)
df2=df.tail(5)
work=pd.ExcelWriter('sales_new.xlsx')
df1.to_excel(work,sheet_name='df1')
df2.to_excel(work,sheet_name='dt2')
work.save