位置: IT常识 - 正文

python-数据描述与分析(1)(数据结构—python语言描述)

编辑:rootadmin
数据描述与分析 在进行数据分析之前,我们需要做的事情是对数据有初步的了解,这个了解就涉及对行业的了解和对数据本身的敏感程度,通俗来说就是对数据的分布有大概的理解,此时我们需要工具进行数据的描述,观测数据的形状等;而后才是对数据进行建模分析,挖掘数据中隐藏的位置信息。目前在数据描述和简单分析方面做的比 ...

推荐整理分享python-数据描述与分析(1)(数据结构—python语言描述),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python数据描述性统计,python数据描述性统计,python数据类型及操作,python数据类型及操作,python数据描述与分析,python 数据描述,python数据描述性统计,python数据描述性统计,内容如对您有帮助,希望把文章链接给更多的朋友!

数据描述与分析

在进行数据分析之前,我们需要做的事情是对数据有初步的了解,这个了解就涉及对行业的了解和对数据本身的敏感程度,通俗来说就是对数据的分布有大概的理解,此时我们需要工具进行数据的描述,观测数据的形状等;而后才是对数据进行建模分析,挖掘数据中隐藏的位置信息。目前在数据描述和简单分析方面做的比较好的是Pandas库。当然,它还需要结合我们之前提到的Numpy,Scipy等科学计算相关库才能发挥功效。

1.Pandas 数据结构 在进行Pandas相关介绍时我们首先需要知道的是Pandas 的两个数据结构(即对象)Series 和 DataFrame,这是Pandas的核心结构,掌握了此二者结构和属性要素,会在具体的数据处理过程中如虎添翼。

1.1 Series 简介 Series 是一种类似于以为数据的对象,它由两部分组成,第一部分是一维数据,另外一部分是与此一维数据对应的标签数据。具体如下:

import pandas as pdcenterSeries =pd.Series(["中国科学院","文献情报中心","大楼","北四环西路",])print (centerSeries)#output:0 中国科学院1 文献情报中心2 大楼3 北四环西路dtype: object

因为我们没有指定它的标签数据,而python默认是通过数字排序进行标识,接下来给他添加标示数据,具体如下:

centerSeries =pd.Series(["中国科学院","文献情报中心","大楼","北四环西路",],index=["a","b","c","d"])print (centerSeries) #index的size和Series的size必须一样长,否则报错#output:a 中国科学院b 文献情报中心c 大楼d 北四环西路dtype: object

对比之前的默认标识,我们可以看出它由1,2,3,4变成了a,b,c,d。接下来将解释这样标识的意义,具体如下:

import pandas as pdcenterSeries =pd.Series(["中国科学院","文献情报中心","大楼","北四环西路",],index=["a","b","c","d"])print (centerSeries[0]) #通过一维数组进行获取数据print (centerSeries[1])print (centerSeries["c"]) #通过标识index获取数据print (centerSeries["d"])#output:中国科学院文献情报中心大楼北四环西路

另外,我们可以看到通过一维数组格式获取数据和通过index标识获取数据都可以,这样的index就像曾经学过的数据库中的id列的作用,相当于建立了每个数据的索引。当然,针对Series的操作不只限于此,还有很多需要我们自己去通过“help”查看得到的。

1.2 DataFrame 简介 DataFrame 是一个表格型的数据结构,它包含有列和行的索引,当然你也可以把它看作是由Series组织成的字典。需要说明的是,DataFrame的每一列中不需要数据类型相同,且它的数据是通过一个或者多个二维块进行存放,在了解DataFrame之前如果读者对层次化索引有所了解,那么DataFrame 可能相对容易理解,当然如果读者并不知道何谓层次化索引也没关系,举个例子:他类似于常见的excel的表格格式,可将它理解为一张excel表,具体如下:

#简单的DataFrame 制作#字典格式的数据data = {"name":["国科图","国科图","文献情报中心","文献情报中心"], "year":["2012","2013","2014","2015"], "local":["北四环西路","北四环西路","北四环西路","北四环西路"], "student":["甲","乙","丙","丁"]}centerDF = pd.DataFrame(data)print(centerDF)#output: name year local student0 国科图 2012 北四环西路 甲1 国科图 2013 北四环西路 乙2 文献情报中心 2014 北四环西路 丙3 文献情报中心 2015 北四环西路 丁#调整列的顺序data = {"local":["北四环西路","北四环西路","北四环西路","北四环西路"],"name":["国科图","国科图","文献情报中心","文献情报中心"],"year":["2012","2013","2014","2015"],"student":["甲","乙","丙","丁"]}centerDF = pd.DataFrame(data,columns=["year","name","local","student"])print(centerDF)#output: year name local student0 2012 国科图 北四环西路 甲1 2013 国科图 北四环西路 乙2 2014 文献情报中心 北四环西路 丙3 2015 文献情报中心 北四环西路 丁#更改index的默认设置data = {"name":["国科图","国科图","文献情报中心","文献情报中心"], "year":["2012","2013","2014","2015"], "local":["北四环西路","北四环西路","北四环西路","北四环西路"], "student":["甲","乙","丙","丁"]}centerDF = pd.DataFrame(data,columns=["year","name","local","student"],index=["a","b","c","d"])print(centerDF)#output: year name local studenta 2012 国科图 北四环西路 甲b 2013 国科图 北四环西路 乙c 2014 文献情报中心 北四环西路 丙d 2015 文献情报中心 北四环西路 丁

既然DataFrame 是行列格式的数据,那么理所当然可以通过行、列的方式进行数据获取,按列进行数据据获取,具体如下:

data = {"name":["国科图","国科图","文献情报中心","文献情报中心"], "year":["2012","2013","2014","2015"], "local":["北四环西路","北四环西路","北四环西路","北四环西路"], "student":["甲","乙","丙","丁"]}centerDF = pd.DataFrame(data,columns=["year","name","local","student"],index=["a","b","c","d"])print (centerDF["name"])print (centerDF["student"])#output:a 国科图b 国科图c 文献情报中心d 文献情报中心Name: name, dtype: objecta 甲b 乙c 丙d 丁Name: student, dtype: objectpython-数据描述与分析(1)(数据结构—python语言描述)

另外,可以看出按列进行获取时他们的index标识是相同的,且每一列是一个Series 对象

按行进行数据获取,其实是通过index进行操作,具体如下:

data = {"name":["国科图","国科图","文献情报中心","文献情报中心"], "year":["2012","2013","2014","2015"], "local":["北四环西路","北四环西路","北四环西路","北四环西路"], "student":["甲","乙","丙","丁"]}centerDF = pd.DataFrame(data,columns=["year","name","local","student"],index=["a","b","c","d"])print (centerDF.loc["a"])#在使用进行DataFrame.ix进行表中的数据块选择的时候,会抛出’DataFrame’ object has no attribute ‘ix’,这个是由于在不同的pandas的版本中,DataFrame的相关属性已过期,已不推荐使用导致的。#参考代码先锋网#output:year 2012name 国科图local 北四环西路student 甲Name: a, dtype: object

另外,同样可以看出每一行是一个Series 对象,此时该Series的index其实就是DataFrame 的列名称,综上来看,对于一个DataFrame 来说,它是纵横双向进行索引,只是每个Series(纵横)都共用一个索引而已

1.3 利用Pandas加载、保存数据在进行数据处理时我们首要工作是把数据加载到内存中,这一度成为程序编辑的软肋,但是Pandas包所提供的功能几乎涵盖了大多数的数据处理的加载问题,如read_csv、read_ExcelFile

(1)加载csv格式的数据

import pandas as pddata_csv = pd.read_csv("D:/python_cailiao/test.csv") #它的默认属性有sep=","data_csv#output:school institute grades name0 中国科学院大学 文献情报中心 15级 田鹏伟1 中国科学院大学 文献情报中心 15级 李四2 中国科学院大学 文献情报中心 15级 王五3 中国科学院大学 文献情报中心 15级 张三data_csv = pd.read_csv("D:/python_cailiao/test.csv",sep="#") #更改默认属性sep="#"data_csv#output:school,institute,grades,name0 中国科学院大学,文献情报中心,15级,田鹏伟1 中国科学院大学,文献情报中心,15级,李四2 中国科学院大学,文献情报中心,15级,王五3 中国科学院大学,文献情报中心,15级,张三data_csv = pd.read_csv("D:/python_cailiao/test.csv",header=None,skiprows=[0]) #不要表头Headerdata_csv#output:school institute grades name0 中国科学院大学 文献情报中心 15级 田鹏伟1 中国科学院大学 文献情报中心 15级 李四2 中国科学院大学 文献情报中心 15级 王五3 中国科学院大学 文献情报中心 15级 张三data_csv.columns=["school","institute","grades","name"]data_csv #自行添加表头列#output:school institute grades name0 中国科学院大学 文献情报中心 15级 田鹏伟1 中国科学院大学 文献情报中心 15级 李四2 中国科学院大学 文献情报中心 15级 王五3 中国科学院大学 文献情报中心 15级 张三

另外,综上,通过对csv格式的文件进行读取,我们可以指定读入的格式(sep=","),也可以指定他的header为空None,最后添加column,而之所以可以后来添加的原因是读入的csv已经是DataFrame格式对象

(2)保存csv数据

data_csv.loc[1,"name"]="顾老师"data_csv.to_csv("D:/python_cailiao/save.csv")

(1)加载excel格式的数据

data_excel = pd.read_excel("D:/python_cailiao/excel.xlsx",sheet_name="test")data_excel#output:school institute grades name0 中国科学院大学 文献情报中心 15级 田鹏伟1 中国科学院大学 文献情报中心 15级 李四2 中国科学院大学 文献情报中心 15级 王五3 中国科学院大学 文献情报中心 15级 张三data_excel.loc[1,"name"]="顾立平老师"data_excel#output:school institute grades name0 中国科学院大学 文献情报中心 15级 田鹏伟1 中国科学院大学 文献情报中心 15级 顾立平老师2 中国科学院大学 文献情报中心 15级 王五3 中国科学院大学 文献情报中心 15级 张三

(2)保存数据

data_excel.to_excel("D:/python_cailiao/save.xlsx",sheet_name="test")

另外,对于excel文件来说同csv格式的处理相差无几,但是excel文件在处理时需要指定sheetname属性(读取和写入sheet_name)

参考书目:《数据馆员的python简明手册》

本文链接地址:https://www.jiuchutong.com/zhishi/311569.html 转载请保留说明!

上一篇:js中typeof操作符是什么(js中typeof用法)

下一篇:织梦dedecms显示当前时间日期的代码(将织梦dedecms转换到wordpress)

  • 花粉俱乐部打不开链接无法读取怎么办(花粉俱乐部进不去怎么办)

    花粉俱乐部打不开链接无法读取怎么办(花粉俱乐部进不去怎么办)

  • office工具需要安装吗(安装office需要什么插件)

    office工具需要安装吗(安装office需要什么插件)

  • ios系统建议更新吗(苹果建议更新最新版本吗)

    ios系统建议更新吗(苹果建议更新最新版本吗)

  • p40充电多久能充满(p40充电多久能充满电池)

    p40充电多久能充满(p40充电多久能充满电池)

  • 显卡温度过高会出现什么现象(显卡温度过高会黑屏吗)

    显卡温度过高会出现什么现象(显卡温度过高会黑屏吗)

  • 微信收款音箱s1和s2和s3区别(微信收款音箱s1怎么拆开)

    微信收款音箱s1和s2和s3区别(微信收款音箱s1怎么拆开)

  • iPhone只能连5gwifi怎么回事(iPhone只能连接5gWiFi)

    iPhone只能连5gwifi怎么回事(iPhone只能连接5gWiFi)

  • win10安装无法告知足够空间(无法安装win 10)

    win10安装无法告知足够空间(无法安装win 10)

  • 淘宝多久自动确认收货(淘宝多久自动确认收货好评)

    淘宝多久自动确认收货(淘宝多久自动确认收货好评)

  • 3601707-a01是什么型号(3601707a01是什么配置)

    3601707-a01是什么型号(3601707a01是什么配置)

  • vivox9手电筒不亮了怎么回事(vivox9i手机手电筒灯不亮咋办)

    vivox9手电筒不亮了怎么回事(vivox9i手机手电筒灯不亮咋办)

  • 苹果id验证码收不到怎么办(苹果id验证码收不到咋回事?)

    苹果id验证码收不到怎么办(苹果id验证码收不到咋回事?)

  • 拼多多可以微信支付吗(拼多多可以微信分期付款吗)

    拼多多可以微信支付吗(拼多多可以微信分期付款吗)

  • log上传限制是什么意思(logs)

    log上传限制是什么意思(logs)

  • 手机程序无响应怎么办(手机程序无响应怎么回事)

    手机程序无响应怎么办(手机程序无响应怎么回事)

  • 拼多多免拼机会有几次(拼多多免拼机会用完了怎么办)

    拼多多免拼机会有几次(拼多多免拼机会用完了怎么办)

  • 苹果11微信视频可以美颜吗(苹果11微信视频怎么开美颜)

    苹果11微信视频可以美颜吗(苹果11微信视频怎么开美颜)

  • 怎样把小米震动关闭(小米手机震动方式)

    怎样把小米震动关闭(小米手机震动方式)

  • 快手双格视频怎么弄(快手怎么分两个格视频)

    快手双格视频怎么弄(快手怎么分两个格视频)

  • 怎么知道自己的电子邮箱(怎么知道自己的罩杯)

    怎么知道自己的电子邮箱(怎么知道自己的罩杯)

  • tim怎么发闪照(tim如何发闪照片)

    tim怎么发闪照(tim如何发闪照片)

  • 微博id是微博名吗(微博id是微博昵称)

    微博id是微博名吗(微博id是微博昵称)

  • 笔记本电源灯不亮开不了机(笔记本电源灯不亮能开机)

    笔记本电源灯不亮开不了机(笔记本电源灯不亮能开机)

  • 在使用WIN7时,为什么桌面图标无法移动?(在windows7操作具有)

    在使用WIN7时,为什么桌面图标无法移动?(在windows7操作具有)

  • AES(ECB/CBC) JS实现加密解密(aes-ecb和aes-gcm)

    AES(ECB/CBC) JS实现加密解密(aes-ecb和aes-gcm)

  • 公司代扣个人所得税有完税凭证明
  • 运输企业内账
  • 进口化妆品需要备案吗
  • 社保申报后不能缴费
  • 深圳增值税发票选择确认平台使用
  • 行政单位库存材料包括哪些
  • 销售发票的会计处理
  • 本月完工入库会计分录
  • 对外支付代扣代缴
  • 资产组减值测试要包含使用权资产吗
  • 向其他单位无偿提供服务的不需缴纳增值税
  • 房地产增值税发票有什么用
  • 自己生产的产品用于职工福利
  • 哪些发票可以用ppt
  • 公司账上的应收账款余额变为负数涉及什么税?
  • 固定资产减值准备增加记哪方
  • 增值税认证未认证是什么意思
  • 营改增后增值税科目
  • 产权转移书据有哪些
  • 商业承兑汇票贴现为什么是短期借款
  • 对公提回贷算收入吗
  • 暂估入库库存出现负数怎么办?
  • 施工项目直接成本和间接成本
  • 企业预付保险费怎么做账
  • PHP:xml_get_error_code()的用法_XML解析器函数
  • php缓存优化
  • 电脑开机弹出网页游戏广告
  • 公司贷款过桥费合法吗
  • word更改单页背景颜色
  • 固定资产拆除怎么处理
  • rtmservice.exe - rtmservice是什么进程 有什么用
  • 集体租赁住房有房产证吗
  • 纽格尔官网
  • 企业会计准则股本
  • 不动产和无形资产的区别
  • 专票认证后可以不抵扣吗
  • 一阶段目标检测算法
  • d2loader does not recognize
  • 软件企业高新技术产品证明材料
  • 中央空调的维护和保养
  • 财报层次和认定层次
  • 完美ui
  • 数据库my sql
  • 营业账簿印花税申报流程
  • 固定资产盘点盘什么
  • 在建工程账务处理会计分录
  • 出口退免税的税种包括增值税消费税企业所得税
  • 授权支付银行有权不给发么
  • 如何理解递延所得税资产和负债
  • 上年计提费用多了,要怎样调
  • 固定资产损失税前扣除备查资料有哪些
  • 外聘人员差旅费用无票调增
  • 股东转公户的钱叫什么
  • 业务招待费进项票可以抵扣吗
  • 收回投标保证金 建立台账
  • 原股东将全部股权转让
  • 库存商品记账
  • sum(case when then)(判断男女生的个数)
  • mysql事务用法
  • xp系统安装软件重复
  • fedora os
  • win8系统怎样查看本机的ip地址
  • Mac系统中使用QuickTime Player实现屏幕录像图文教程
  • windows无法配置在此硬件上运行
  • linux root用户登陆
  • 启动windows安全中心
  • ssh远程登录设置
  • 联想 恢复
  • flask操作mysql数据库
  • perl -pi
  • js 操作excel
  • SendTo增强版 批处理实用小工具
  • macos如何使用
  • unity控制相机旋转
  • 基于javascript的毕业设计
  • 基于Android的游戏陪玩APP设计
  • 南宁地方税务局网站
  • 为什么医保名字不一样
  • 国税优盘安装教程
  • 广州市地方税务局 社保费申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设