利用Python进行数据分析_Pandas_数据加载、存储与文件格式
申明:本系列文章是自己在学习《利用Python进行数据分析》这本书的过程中,为了方便后期自己巩固知识而整理。
1 pandas读取文件的解析函数
read_csv 读取带分隔符的数据,默认分隔符 逗号
read_table 读取带分隔符的数据,默认分隔符 “\t”
read_fwf 读取定宽、列格式数据(无分隔符)
read_clipboard 读取剪贴板中的数据(将网页转换为表格)
1.1 读取excel数据
import pandas as pd
import numpy as np
file = 'D:\example.xls'
pd = pd.read_excel(file)
pd
运行结果:

1.1.1 不显示表头
pd = pd.read_excel(file,header=None)
运行结果:

1.1.2 设置表头
pd = pd.read_excel(file,names=['Year','Name','Math','Chinese','EngLish','Avg'])
运行结果:

1.1.3 指定索引
pd = pd.read_excel(file,index_col= '姓名')
运行结果:

2 读取CSV数据
import pandas as pd
import numpy as np
pd = pd.read_csv("d:\\test.csv",engine='python')
pd
运行结果:

import pandas as pd
import numpy as np
pd = pd.read_table("d:\\test.csv",engine='python')
pd
运行结果:

import pandas as pd
import numpy as np
pd = pd.read_fwf("d:\\test.csv",engine='python')
pd
运行结果:

3 将数据写出到文本格式
将数据写出到csv格式,默认分隔符 逗号
import pandas as pd
import numpy as np
pd = pd.read_fwf("d:\\test.csv",engine='python')
pd.to_csv("d:\\test1.csv",encoding='gbk')
运行结果:

4 手工处理分隔符格式
单字符分隔符文件,直接用csv模块
import pandas as pd
import numpy as np
import csv
file = 'D:\\test.csv'
pd = pd.read_csv(file,engine='python')
pd.to_csv("d:\\test1.csv",encoding='gbk',sep='/')
f = open("d:\\test1.csv")
reader = csv.reader(f)
for line in reader:
print(line)
运行结果:

4.1 缺失值填充
import pandas as pd
import numpy as np
import csv
file = 'D:\\test.csv'
pd = pd.read_csv(file,engine='python')
pd.to_csv("d:\\test1.csv",encoding='gbk',sep='/',na_rep='NULL')
f = open("d:\\test1.csv")
reader = csv.reader(f)
for line in reader:
print(line)
运行结果:

4.2 JSON
4.2.1 json.loads 可将JSON字符串转换成Python形式
import pandas as pd
import numpy as np
import json
obj = """{
"sucess" : "1",
"header" : {
"version" : 0,
"compress" : false,
"times" : 0
},
"data" : {
"name" : "BankForQuotaTerrace",
"attributes" : {
"queryfound" : "1",
"numfound" : "1",
"reffound" : "1"
},
"columnmeta" : {
"a0" : "DATE",
"a1" : "DOUBLE",
"a2" : "DOUBLE",
"a3" : "DOUBLE",
"a4" : "DOUBLE",
"a5" : "DOUBLE",
"a6" : "DATE",
"a7" : "DOUBLE",
"a8" : "DOUBLE",
"a9" : "DOUBLE",
"b0" : "DOUBLE",
"b1" : "DOUBLE",
"b2" : "DOUBLE",
"b3" : "DOUBLE",
"b4" : "DOUBLE",
"b5" : "DOUBLE"
},
"rows" : [ [ "2017-10-28", 109.8408691012081, 109.85566362201733, 0.014794520809225841, 1.0, null, "", 5.636678251676443, 5.580869556115291, 37.846934105222246, null, null, null, null, null, 0.061309012867495856 ] ]
}
}
"""
result = json.loads(obj)
result
运行结果:

4.2.2 json.dumps可将Python字符串转换成JSON形式
result = json.loads(obj)
asjson=json.dumps(result)
asjson
运行结果:

4.2.3 JSON数据转换成DataFrame
import pandas as pd
import numpy as np
from pandas import DataFrame
import json
obj = """{
"sucess" : "1",
"header" : {
"version" : 0,
"compress" : false,
"times" : 0
},
"data" : {
"name" : "BankForQuotaTerrace",
"attributes" : {
"queryfound" : "1",
"numfound" : "1",
"reffound" : "1"
},
"columnmeta" : {
"a0" : "DATE",
"a1" : "DOUBLE",
"a2" : "DOUBLE",
"a3" : "DOUBLE",
"a4" : "DOUBLE",
"a5" : "DOUBLE",
"a6" : "DATE",
"a7" : "DOUBLE",
"a8" : "DOUBLE",
"a9" : "DOUBLE",
"b0" : "DOUBLE",
"b1" : "DOUBLE",
"b2" : "DOUBLE",
"b3" : "DOUBLE",
"b4" : "DOUBLE",
"b5" : "DOUBLE"
},
"rows" : [ [ "2017-10-28", 109.8408691012081, 109.85566362201733, 0.014794520809225841, 1.0, null, "", 5.636678251676443, 5.580869556115291, 37.846934105222246, null, null, null, null, null, 0.061309012867495856 ] ]
}
}
"""
result = json.loads(obj)
result
jsondf = DataFrame(result['data'],columns = ['name','attributes','columnmeta'],index={1,2,3})
jsondf
运行结果:

备注:其中attributes和columnmeta,存在嵌套,这个问题后面再补充。
4.3 XML和HTML
爬取同花顺网页中的列表数据,并转换成DataFrame

在爬取的时候,我这里没有考虑爬分页的数据,有兴趣的可以自己尝试,我这里主要是想尝试爬取数据后转成DataFrame
代码如下:
import pandas as pd
import numpy as np
from pandas.core.frame import DataFrame
from lxml.html import parse
import requests
from bs4 import BeautifulSoup
import time url = 'http://data.10jqka.com.cn/market/longhu/'
headers = {"User-Agent":"Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36"}
response = requests.get(url = url,headers = headers)
html = response.content
soup = BeautifulSoup(html, 'lxml')
s = soup.find_all('div','yyb') # 获取dataframe所需的columns
def getcol():
col = []
for i in s:
lzs = i.find_all('thead')
for k in lzs:
lbs = k.find_all('th')
for j in lbs:
col.append(j.text.strip('\n'))
return col # 获取dataframe所需的values
def getvalues():
val = []
for j in s:
v = j.find_all('tbody')
for k in v:
vv = k.find_all('tr')
list = []
for l in vv:
tdlist = []
vvv = l.find_all('td')
for m in vvv:
tdlist.append(m.text)
list.append(tdlist)
return(list) if __name__ == "__main__":
cols = getcol()
values = getvalues()
data=DataFrame(values,columns=cols)
print(data)
运行结果:

4.4 二进制数据格式
pandas对象的save方法保存,load方法读回到Python
4.5 HDF5格式
HDF是层次型数据格式,HDF5文件含一个文件系统式的节点结构,支持多个数据集、元数据,可以高效的分块读写。Python中的HDF5库有2个接口:PyTables和h5py。
海量数据应该考虑用这个,现在我没用着,先不研究了。
4.6 使用HTML和Web API
import requests
import pandas as pd
from pandas import DataFrame
import json
url = 'http://t.weather.sojson.com/api/weather/city/101030100'
resp = requests.get(url)
data = json.loads(resp.text)#这里的data是一个dict
jsondf = DataFrame(data['cityInfo'],columns =['city','cityId','parent','updateTime'],index=[1])#实例化
jsondf

运行结果:

4.7 使用数据库
4.7.1 sqlite3
import sqlite3
import pandas.io.sql as sql
con = sqlite3.connect()
sql.read_frame('select * from test',con)#con 是一个连接对象
4.7.1 MongoDB
没装。先搁置。
利用Python进行数据分析_Pandas_数据加载、存储与文件格式的更多相关文章
- 利用python进行数据分析之数据加载存储与文件格式
在开始学习之前,我们需要安装pandas模块.由于我安装的python的版本是2.7,故我们在https://pypi.python.org/pypi/pandas/0.16.2/#downloads ...
- 利用Python进行数据分析_Pandas_数据清理、转换、合并、重塑
1 合并数据集 pandas.merge pandas.merge(left, right, how='inner', on=None, left_on=None, right_on=None, le ...
- python数据分析笔记——数据加载与整理]
[ python数据分析笔记——数据加载与整理] https://mp.weixin.qq.com/s?__biz=MjM5MDM3Nzg0NA==&mid=2651588899&id ...
- 利用Python进行数据分析_Pandas_处理缺失数据
申明:本系列文章是自己在学习<利用Python进行数据分析>这本书的过程中,为了方便后期自己巩固知识而整理. 1 读取excel数据 import pandas as pd import ...
- 利用Python进行数据分析_Pandas_数据结构
申明:本系列文章是自己在学习<利用Python进行数据分析>这本书的过程中,为了方便后期自己巩固知识而整理. 首先,需要导入pandas库的Series和DataFrame In [21] ...
- 利用Python进行数据分析_Pandas_层次化索引
申明:本系列文章是自己在学习<利用Python进行数据分析>这本书的过程中,为了方便后期自己巩固知识而整理. 层次化索引主要解决低纬度形式处理高纬度数据的问题 import pandas ...
- 利用Python进行数据分析_Pandas_基本功能
申明:本系列文章是自己在学习<利用Python进行数据分析>这本书的过程中,为了方便后期自己巩固知识而整理. 第一 重新索引 Series的reindex方法 In [15]: obj = ...
- 利用Python进行数据分析_Pandas_汇总和计算描述统计
申明:本系列文章是自己在学习<利用Python进行数据分析>这本书的过程中,为了方便后期自己巩固知识而整理. In [1]: import numpy as np In [2]: impo ...
- 利用python进行数据分析之数据规整化
数据分析和建模大部分时间都用在数据准备上,数据的准备过程包括:加载,清理,转换与重塑. 合并数据集 pandas对象中的数据可以通过一些内置方法来进行合并: pandas.merge可根据一个或多个键 ...
随机推荐
- cmake入门之内部构建
https://www.cnblogs.com/coderfenghc/tag/cmake/ https://cmake.org/cmake/help/v3.16/guide/tutorial/ind ...
- ES里设置索引中倒排列表仅仅存文档ID——采用docs存储后可以降低pos文件和cfs文件大小
index_options The index_options parameter controls what information is added to the inverted index, ...
- 基于Python的GMSSL实现
基于Python的GMSSL实现 团队任务 一.小组讨论对课程设计任务的理解 基于Python的GMSSL实现,即GmSSL开源加密包的python实现,支持其SM2/SM3/SM4等国密(国家商用密 ...
- Vue 缓存当前页面keep-alive
需求: 产品经理在列表页(几千个数据,n个page)点击某一项进去到详情页后,再返回到列表页发现页面回到了第一页,找不到之前的查看的是哪一条了,为了方便咋公司产品经理,返回列表页时需要记住之前的pag ...
- MySQL数据类型(最大值 和 最小值)
MySQL数据类型(最大值 和 最小值) 1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-3276 ...
- MySQL之二进制日志
一.Binlog日志格式 根据日志定义的格式不一样,可以分为Statement格式.Row格式或者MIXED格式 mysql5.6----> | binlog_format | STATEMEN ...
- nginx在windows系统中如何启动、重启、停止
nginx在windows系统中如何启动.重启.停止 查看nginx的版本号:nginx -v 启动nginx:start nginx 快速停止或关闭nginx:nginx -s stop 正常停 ...
- 解析python 命令的-u参数
在shell脚本中运行python 命令时后面加了-u 参数(python -u xx.py),这个-u表示什么? import sys sys.stdout.write("stdout1& ...
- 123457123456#0#-----com.threeapp.MakerHanBao01----儿童汉堡制作游戏
----com.threeapp.MakerHanBao01----儿童汉堡制作游戏
- InfluxDB+Grafana大数据监控系列之数据源配置(二)
一.Grafana 配置 InfluxDB 数据源 1.1 登录 Granfana 界面选择 InfluxDB 数据源 在前面我们已经部署好相应监控环境,登录Grafana:http://10.223 ...