首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

python数据科学系列:pandas入门详细教程

导读 前2篇分别系统性介绍了numpy和matplotlib的入门基本知识,今天本文自然是要对pandas进行入门详细介绍,通过本文你将系统性了解pandas为何会有数据分析界"瑞士军刀"的盛誉。...、切片访问、通函数、广播机制等 series是带标签的一维数组,所以还可以看做是类字典结构:标签是key,取值是value;而dataframe则可以看做是嵌套字典结构,其中列名是key,每一列的series...所以从这个角度讲,pandas数据创建的一种灵活方式就是通过字典或者嵌套字典,同时也自然衍生出了适用于series和dataframe的类似字典访问的接口,即通过loc索引访问。...自然毫无悬念 dataframe:无法访问单个元素,只能返回一列、多列或多行:单值或多值(多个列名组成的列表)访问时按列进行查询,单值访问不存在列名歧义时还可直接用属性符号" ....例如,当标签列类型(可通过df.index.dtype查看)为时间类型时,若使用无法隐式转换为时间的字符串作为索引切片,则引发报错 ? 切片形式返回行查询,且为范围查询 ?

15.1K21

Pandas

进行切片,对行的指定要使用索引或者条件,对列的索引必须使用列名称,如果有多列,则还需要借助[]将列名称括起来。...reindex 时还可以进行缺失值的填充,一个方法是’ffill’(“forward-fills”),实现对缺失索引的前向填充: 一般来说,我们很少使用 df 的多级列标签,更多的情况是将列标签转化为行标签...DataFrame 中直接转换为 Timestamp 格式外,还可以将数据单独提取出来将其转换为 DatetimeIndex 或者 PeriodIndex。...使用 transform 方法聚合数据 Pandas 提供了transform()方法对 DataFrame 对象和分组对象的指定列进行统计计算,统计计算可以使用用户自定义函数。...对于非数值类数据的统计可以使用astype方法将目标特征的数据类型转换为category类别 Pandas 提供了按照变量值域进行等宽分割的pandas.cut()方法。

9.2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Python环境】Python中的结构化数据分析利器-Pandas简介

    创建DataFrame有多种方式: 以字典的字典或Series的字典的结构构建DataFrame,这时候的最外面字典对应的是DataFrame的列,内嵌的字典及Series则是其中每个值。...从列表的字典构建DataFrame,其中嵌套的每个列表(List)代表的是一个列,字典的名字则是列标签。这里要注意的是每个列表中的元素数量应该相同。...只是思路略有不同,一个是以列为单位构建,将所有记录的不同属性转化为多个Series,行标签冗余,另一个是以行为单位构建,将每条记录转化为一个字典,列标签冗余。...df.groupby(['A','B']).sum()##按照A、B两列的值分组求和 对应R函数: tapply() 在实际应用中,先定义groups,然后再对不同的指标指定不同计算方式。...groups = df.groupby('A')#按照A列的值分组求和groups['B'].sum()##按照A列的值分组求B组和groups['B'].count()##按照A列的值分组B组计数 默认会以

    15.1K100

    Pandas全景透视:解锁数据科学的黄金钥匙

    了解完这些,接下来,让我们一起探索 Pandas 中那些不可或缺的常用函数,掌握数据分析的关键技能。①.map() 函数用于根据传入的字典或函数,对 Series 中的每个元素进行映射或转换。...具体来说,map()函数可以接受一个字典或一个函数作为参数,然后根据这个字典或函数对 Series 中的每个元素进行映射或转换,生成一个新的 Series,并返回该 Series。...如果传入的是一个字典,则 map() 函数将会使用字典中键对应的值来替换 Series 中的元素。如果传入的是一个函数,则 map() 函数将会使用该函数对 Series 中的每个元素进行转换。...11 22 33 4dtype: object⑥.pd.cut()函数将连续性数值进行离散化处理:如对年龄、消费金额等进行分组pandas.cut(x, bins, right=True...3 6 9在本文中,我们深入探讨了Pandas库中一系列高效的数据处理方法。

    11710

    Python常用小技巧总结

    Pandas数据分析常用小技巧 ---- 数据分析中pandas的小技巧,快速进行数据预处理,欢迎点赞收藏,持续更新,作者:北山啦 ---- ---- 文章目录 Pandas数据分析常用小技巧 Pandas...小技巧 pandas生成数据 导入数据 导出数据 查看数据 数据选择 数据处理 数据分组 数据合并 数据替换--map映射 数据清洗--replace和正则 数据透视表分析--melt函数 将分类中出现次数较少的值归为...df1.join(df2.set_index(col1),on=col1,how='inner') # 对df1的列和df2的列执⾏SQL形式的join,默认按照索引来进⾏合并,如果df1和df2有共同字段时...> 2 3 Name: sales, dtype: object 数据透视表分析–melt函数 melt是逆转操作函数,可以将列名转换为列数据...下面的列表推导式将对行和列进行转置 matrix = [ [1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], ] [[row[i] for

    9.4K20

    Pandas中的这3个函数,没想到竟成了我数据处理的主力

    对象经过groupby分组后调用apply时,数据处理函数作用于groupby后的每个子dataframe上,即作用对象还是一个DataFrame(行是每个分组对应的行;列字段少了groupby的相应列...那么应用apply到一个DataFrame的每个Series,自然存在一个问题是应用到行还是列的问题,所以一个DataFrame调用apply函数时需要指定一个axis参数,其中axis=0对应行方向的处理...为实现这一数据统计,则首先应以舱位等级作为分组字段进行分组,而后对每个分组内的数据进行聚合统计,示例代码如下: ?...而在Pandas框架中,这两种含义都有所体现:对一个Series对象的每个元素实现字典映射或者函数变换,其中后者与apply应用于Series的用法完全一致,而前者则仅仅是简单将函数参数替换为字典变量即可...分组后的group DataFrame,分别实现元素级、Series级以及DataFrame级别的数据变换; map仅可作用于Series实现元素级的变换,既可以接收一个字典完成变化也可接收特定的函数,

    2.5K10

    python下的Pandas中DataFrame基本操作(二),DataFrame、dict、array构造简析

    DataFrame既有行索引也有列索引,它可以被看做由Series组成的字典(共用同一个索引)。...2001 Ohio 1.7 three 2002 Ohio 3.6 four 2001 Nevada 2.4 five 2002 Nevada 2.9 需要注意的是:将列表或数组赋值给某个列时...: Shape of passed values is (3, 5), indices imply (3, 4) 2:传入一个由嵌套的字典;   它就会被解释为:外层字典的键作为列,内层键则作为行索引。..."b" : b}#将列表a,b转换成字典 data=DataFrame(c)#将字典转换成为数据框 print(data) 输出的结果为 a b 0 1 5 1 2 6 2 3...7 3 4 8 第二种:将包含不同子列表的列表转换为数据框 from pandas.core.frame import DataFrame a=[[1,2,3,4],[5,6,7,8]]#包含两个不同的子列表

    4.5K30

    python数据分析——数据分类汇总与统计

    例如, DataFrame可以在其行(axis=0)或列(axis=1)上进行分组。然后,将一个函数应用(apply)到各个分组并产生一个新值。...程序代码如下所示: people.groupby(len).sum() 将函数跟数组、列表、字典、Series混合使用也不是问题,因为任何东西在内部都会被转换为数组 key_list = ['one',...具体的办法是向agg传入一个从列名映射到函数的字典: 只有将多个函数应用到至少一列时,DataFrame才会拥有层次化的列 2.3.返回不含行索引的聚合数据 到目前为止,所有例中的聚合数据都有由唯一的分组键组成的索引...首先,编写一个选取指定列具有最大值的行的函数: 现在,如果对smoker分组并用该函数调用apply,就会得到: top函数在DataFrame的各个片段调用,然后结果由pandas.concat...label:表示降采样时设置聚合值的标签。 convention:重采样日期时,低频转高频采用的约定,可以取值为start或end,默认为start。

    84010

    Python|Pandas的常用操作

    Pandas的主要特点 基于Numpy创建,继承了Numpy中优秀的特点; 能够直接读取结构化数据进行操作; 以类似于表格的形式呈现数据,便于观察; 提供了大量的数理统计方法。...Pandas主要的数据结构 Series:带标签的一维同构数组; DataFrame:带标签的,大小可变的,二维异构表格。...# 我们不能直接查看分组后的结果,要进行一些其他的操作 df5.groupby('A') # 根据分组统计数值和 df5.groupby('A').sum() # 对分组进行迭代 for name..., group in df5.groupby('B'): print(name) print(group) # 将分组结果转换为字典 piece = dict(list(df5.groupby...('B'))) 13 神奇的apply函数 apply()函数会遍历每一个元素,对元素运行指定的function,具体的用法如下所示: # 进行矩阵的平方运算 matrix = [[1, 2, 3]

    2.1K40

    在 Python 中,通过列表字典创建 DataFrame 时,若字典的 key 的顺序不一样以及部分字典缺失某些键,pandas 将如何处理?

    当通过列表字典来创建 DataFrame 时,每个字典通常代表一行数据,字典的键(key)对应列名,而值(value)对应该行该列下的数据。如果每个字典中键的顺序不同,pandas 将如何处理呢?...列顺序:在创建 DataFrame 时,pandas 会检查所有字典中出现的键,并根据这些键首次出现的顺序来确定列的顺序。...df = pd.DataFrame(data, dtype=np.float64):这行代码使用 pandas 的 DataFrame 函数将 data 列表转换为 DataFrame。...总的来说,这段代码首先导入了所需的库,然后创建了一个包含多个字典的列表,最后将这个列表转换为 DataFrame,并输出查看。...总而言之,pandas 在处理通过列表字典创建 DataFrame 时各个字典键顺序不同以及部分字典缺失某些键时显示出了极高的灵活性和容错能力。

    13500

    python数据分析——数据分类汇总与统计

    例如, DataFrame可以在其行(axis=0)或列(axis=1)上进行分组。然后,将一个函数应用(apply)到各个分组并产生一个新值。...程序代码如下所示: people.groupby(len).sum() 将函数跟数组、列表、字典、Series混合使用也不是问题,因为任何东西在内部都会被转换为数组 key_list = ['one',...具体的办法是向agg传入一个从列名映射到函数的字典: 只有将多个函数应用到至少一列时,DataFrame才会拥有层次化的列 返回不含行索引的聚合数据 到目前为止,所有例中的聚合数据都有由唯一的分组键组成的索引...首先,编写一个选取指定列具有最大值的行的函数: 现在,如果对smoker分组并用该函数调用apply,就会得到: top函数在DataFrame的各个片段调用,然后结果由pandas.concat...它可以改变时间序列数据的频率,将数据从高频率转换为低频率(如从天到月),或者将数据从低频率转换为高频率(如从月到天)。重采样可以帮助我们对数据进行更好的分析和可视化。

    15210

    【精心解读】用pandas处理大数据——节省90%内存消耗的小贴士

    Dataframe对象的内部表示 在底层,pandas会按照数据类型将列分组形成数据块(blocks)。...他扮演一个API,提供对底层数据的访问。每当我们查询、编辑或删除数据时,dataframe类会利用BlockManager类接口将我们的请求转换为函数和方法的调用。...这对我们原始dataframe的影响有限,这是由于它只包含很少的整型列。 同理,我们再对浮点型列进行相应处理: 我们可以看到所有的浮点型列都从float64转换为float32,内存用量减少50%。...Pandas用一个字典来构建这些整型数据到原数据的映射关系。当一列只包含有限种值时,这种设计是很不错的。...总结 我们学习了pandas如何存储不同的数据类型,并利用学到的知识将我们的pandas dataframe的内存用量降低了近90%,仅仅只用了一点简单的技巧: 将数值型列降级到更高效的类型 将字符串列转换为类别类型

    8.7K50

    pandas

    列中的日期转换为没有时分秒的日期 df.to_excel("dates.xlsx") 向pandas中插入数据 如果想忽略行索引插入,又不想缺失数据与添加NaN值,建议使用 df['column_name...在我们使用append合并时,可能会弹出这个错误,这个问题就是pandas版本问题,高版本的pandas将append换成了-append results = results.append(temp,..._append(temp, ignore_index=True) pandas数据转置 与矩阵相同,在 Pandas 中,我们可以使用 .transpose() 方法或 .T 属性来转置 我们的DataFrame...通常情况下, 因为.T的简便性, 更常使用.T属性来进行转置 注意 转置不会影响原来的数据,所以如果想保存转置后的数据,请将值赋给一个变量再保存。...对象,将列表作为一列数据 df = pd.DataFrame(data, columns=['姓名']) df_transposed = df.T # 保存为行 # 将 DataFrame

    13010

    (数据科学学习手札69)详解pandas中的map、apply、applymap、groupby、agg

    ,用于对单列、多列数据进行批量运算或分组聚合运算,熟悉这些方法后可极大地提升数据分析的效率,也会使得你的代码更加地优雅简洁,本文就将针对pandas中的map()、apply()、applymap()、...gender列的F、M转换为女性、男性的新列,可以有以下几种实现方式: ● 字典映射   这里我们编写F、M与女性、男性之间一一映射的字典,再利用map()方法来得到映射列: #定义F->女性,M->男性的映射字典...三、聚合类方法   有些时候我们需要像SQL里的聚合操作那样将原始数据按照某个或某些离散型的列进行分组再求和、平均数等聚合之后的值,在pandas中分组运算是一件非常优雅的事。...当变量为1个时传入名称字符串即可,当为多个时传入这些变量名称列表,DataFrame对象通过groupby()之后返回一个生成器,需要将其列表化才能得到需要的分组后的子集,如下面的示例: #按照年份和性别对婴儿姓名数据进行分组...3.2 利用agg()进行更灵活的聚合   agg即aggregate,聚合,在pandas中可以利用agg()对Series、DataFrame以及groupby()后的结果进行聚合,其传入的参数为字典

    5.1K60
    领券