import pandas as pd
import numpy as np
# 自动创建索引
obj = pd.Series([4, 7, -5, 2])
print(obj, type(obj))
print(obj.values)
print(obj.index) # 自己创建索引
obj2 = pd.Series([2, 5, -32, 3], index=['a', 'b', 'c', 'd'])
print(obj2)
print(obj2['a']) # 通过索引拿取值
print(obj2[['a', 'c']]) # 数组运算
print(obj2[obj2 > 0])
print(obj2 * 2)
print('b' in obj2) # 可以通过字典来创建Series
sdata = {'zhangbo': 110, 'zhangwu': 150}
obj3 = pd.Series(sdata)
print(obj3)
# 自动找到对应的索引
states = ['zhangwu', 'zhangbo', 'zhangkai']
obj4 = pd.Series(sdata, index=states)
print(obj4)
print(pd.isnull(obj4))
print(pd.notnull(obj4))
print(obj4.isnull())
print(obj3 + obj4) # name属性
obj4.name = 'sea'
obj4.index.name = 'state'
print(obj4) # 索引通过赋值方式进行修改
obj.index = ['bob', 'steve', 'jeff', 'ryan']
print(obj) # DataFrame第二种pandas中的数据类型,表格型数据结构,数据框
# 既有行索引,又有列索引
data = {
'state': ['ohio', 'ohio', 'ohio', 'nevada', 'nevada'],
'year': [2000, 2001, 2002, 2001, 2002],
'pop': [1.5, 1.7, 3.6, 2.4, 2.9]
}
# 自动创建索引 0 - N-1
frame = pd.DataFrame(data)
print(frame)
# 按指定列进行排列
frame = pd.DataFrame(data, columns=['year', 'state', 'pop'])
print(frame) # 传入的列找不到数据,则产生NA值, 可以自己创建索引
frame2 = pd.DataFrame(data, columns=['year', 'state', 'pop', 'debt'], index=['one', 'two', 'three', 'four', 'five'])
print(frame2)
print(frame2.columns) # 单独打印列的名称
print(frame2['state']) # 获取列
print(frame2.ix['two']) # 获取行
frame2['debt'] = 16.5 # 修改列的值
frame2['debt'] = np.arange(5) # 自增
print(frame2)
# 列表或者数组赋值给列, Series精确匹配
val = pd.Series([-23, 3, -4], index=['two', 'four', 'five'])
frame2['debt'] = val
print(frame2)
# 为不存在的列赋值会创造一个新列
frame2['eastern'] = frame2.state == 'ohio'
print(frame2)
del frame2['eastern'] # 关键字del用于删除列
print(frame2) # 嵌套字典(字典的字典)
pop = {
'nevada': {
2001: 2.4,
2002: 2.9
},
'ohio': {
2000: 1.5,
2001: 1.7,
2002: 3.6
}
}
frame3 = pd.DataFrame(pop)
print(frame3) # 内层的键会合并形成最终的索引,如果指定索引,则不会这样
print(frame3.T) # 进行转置
frame3 = pd.DataFrame(pop, index=[2001, 2002, 2003]) # 如果指定索引,则不会这样
print(frame3)
# data数据类型是可以切割的
pdata = {
'ohio': frame3['ohio'][:-1],
'nevada': frame3['nevada'][:2]
}
frame4 = pd.DataFrame(pdata)
print(frame4)
# 设置index和columns的name属性,这些信息也会被显现出来
frame3.index.name = 'year'
frame3.columns.name = 'state'
print(frame3)
print(frame3.values) # 单独获取值
print(frame2.values)

pandas入门(1)的更多相关文章

  1. 利用Python进行数据分析——pandas入门

    利用Python进行数据分析--pandas入门 基于NumPy建立的 from pandas importSeries,DataFrame,import pandas as pd 一.两种数据结构 ...

  2. Python 数据处理库 pandas 入门教程

    Python 数据处理库 pandas 入门教程2018/04/17 · 工具与框架 · Pandas, Python 原文出处: 强波的技术博客 pandas是一个Python语言的软件包,在我们使 ...

  3. 利用python进行数据分析之pandas入门

    转自https://zhuanlan.zhihu.com/p/26100976 目录: 5.1 pandas 的数据结构介绍5.1.1 Series5.1.2 DataFrame5.1.3索引对象5. ...

  4. 利用python进行数据分析--pandas入门2

    随书练习,第五章  pandas入门2 # coding: utf-8 # In[1]: from pandas import Series,DataFrame import pandas as pd ...

  5. 利用python进行数据分析--pandas入门1

    随书练习,第五章  pandas入门1 # coding: utf-8 # In[1]: from pandas import Series, DataFrame # In[2]: import pa ...

  6. pandas 入门(3)

    from pandas import Series, DataFrame, Index import numpy as np # 层次化索引 对数据重塑和分组操作很有用 data = Series(n ...

  7. < 利用Python进行数据分析 - 第2版 > 第五章 pandas入门 读书笔记

    <利用Python进行数据分析·第2版>第五章 pandas入门--基础对象.操作.规则 python引用.浅拷贝.深拷贝 / 视图.副本 视图=引用 副本=浅拷贝/深拷贝 浅拷贝/深拷贝 ...

  8. 程序员用于机器学习编程的Python 数据处理库 pandas 入门教程

    入门介绍 pandas适合于许多不同类型的数据,包括: · 具有异构类型列的表格数据,例如SQL表格或Excel数据 · 有序和无序(不一定是固定频率)时间序列数据. · 具有行列标签的任意矩阵数据( ...

  9. 《利用python进行数据分析》读书笔记--第五章 pandas入门

    http://www.cnblogs.com/batteryhp/p/5006274.html pandas是本书后续内容的首选库.pandas可以满足以下需求: 具备按轴自动或显式数据对齐功能的数据 ...

  10. pandas入门

    [原]十分钟搞定pandas   本文是对pandas官方网站上<10 Minutes to pandas>的一个简单的翻译,原文在这里.这篇文章是对pandas的一个简单的介绍,详细的介 ...

随机推荐

  1. Codeforces Round #430 (Div. 2) - A

    题目链接:http://codeforces.com/contest/842/problem/A 题意:给定l,r,x,y,k.问是否存在a (l<=a<=r) 和b (x<=b&l ...

  2. VS 2012 Unit Test

    1,Open Tool->Custmoize 2,Create Unit Tests Move Down Run Test 3,Restart run VS 4,Create UnitTest ...

  3. visual studio中配置opencv

    第1步附加包含目录:H:\software\programming\opencv\opencv\build\include 第2步附加库目录:H:\software\programming\openc ...

  4. noip2017简要题解。

    重新写了一下去年的题来看看自己到底是有多傻逼. 小凯的疑惑 打表. 时间复杂度 搞了一大坨题面,但是真正有用的信息只有几个: 判断他给你的复杂度是多少. 判断当前循环进不进的去. 判断当前循环产生的贡 ...

  5. vuex使用方法

    vuex是一个专门为vue.js设计的集中式状态管理架构.状态?我把它理解为在data中的属性需要共享给其他vue组件使用的部分,就叫做状态.简单的说就是data中需要共用的属性.比如:我们有几个页面 ...

  6. 对Nuxt的研究

    Nuxt就是基于Vue的一个应用框架,采用服务端渲染,让你的SPA应用(Vue)也可以拥有SEO Nuxt的生命周期有些在服务端(Node),客户端,甚至两边都在: 1.其他之前都不存在Window对 ...

  7. Comet OJ - Contest #7 D 机器学习题 斜率优化 + 未调完

    Code: #include <cstdio> #include <algorithm> #include <cstring> #define setIO(s) f ...

  8. 七牛云对象存储kodo使用体验

    在这里,我使用了七牛云的对象存储Kodo,和阿里云的OSS,还有腾讯云的COS是同样的产品 oss相关术语 包依赖关系解决 unrecognized import path "golang. ...

  9. linux使用shell 进行文件数据的读取与排序

    题目 shell脚本语言编写一个从键盘输入10名学生(含自己)的姓名. 性别.学号和家庭住址,然后按照学号排序,并将排序后的结果在屏幕上按对齐 的方式打印输出的程序. 代码 读入数据 数据排序(这里用 ...

  10. Zookeeper w3cschool教程

    1.简介 ZooKeeper是一种分布式协调服务,用于管理大型主机.在分布式环境中协调和管理服务是一个复杂的过程.ZooKeeper通过其简单的架构和API解决了这个问题. ZooKeeper允许开发 ...