python——pandas关于数据处理的库

很多函数基于numpy库,主要用于数据的预处理阶段。

一、数据读取

pandas.read_csv():读取数据文件

DataFrame类型:和矩阵很像,有行有列。可以包含几种类型的结构,其中将字符型的值称作“object”。

.head函数:显示刚才读取的前几条数据,默认是5

.tail()函数:显示最后几行的数据

.columns:显示列名

.shape:看矩阵的大小(样本数,指标数)

dtype的类型有这些:object(String value)/ int/ float/ datatime/bool

import pandas

food_info=pandas.read_csv('food_info.csv')
print(type(food_info)) #查看food_info的数据类型 dataFrame类型
print(food_info.dtypes) #查看food_info中每一项数据是什么类型
print(food_info.columns) # 查看所有的列名称,返回一个元组类型
print(help(pandas.read_csv)) #获取帮助

print(food_info.head(3))
print(food_info.tail(2))
print(food_info.shape) #(8618, 36)

二、索引与计算

1. 访问行、列(记录,属性)

# 访问行:一行,特定的几行,从某行到某行
print(food_info.loc[0]) #注意:这个同矩阵不同,输出的并不是实际表格中的第一行,二是第二行,也就是表格中的第一个记录
print(food_info.loc[[1,2]]) #将要想要访问的行数以列表的形式传入
print(food_info.loc[1:3]) #注意,此时只有一个大括号

# 访问列:一列,特定的几列
print(food_info["Water_(g)"]) #打印Water_(g)这一列的所有值
print(food_info[['NDB_No','Water_(g)']]) #打印 'NDB_No','Water_(g)'这两列的值

# 输出所有列名
col_name=food_info.columns.tolist() #以列的形式输出所有的属性名称
print(col_name)

# 输出以“”为结尾的列
gram_columns=[]
for c in col_name:
    if c.endswith('(g)'):
        gram_columns.append(c) #python原有的,列表的常用函数,增加元素
gram_df=food_info[gram_columns]
print(gram_df)

2. 运算,增加属性(就像字典那样,直接增加,但是要注意,维度要相等)

# 除法:将单位是mg等人化为g,并放在一个新的列中
Iron_gram=food_info['Iron_(mg)']/1000
print(food_info.shape) #(8618, 36)
food_info['Iron_(g)']=Iron_gram
print(food_info.shape) #(8618, 37)

#乘法,相同维度的,就是点乘了,对应位置相乘
water_energy=food_info['Water_(g)']*food_info['Energ_Kcal']
print(water_energy)

3. 寻找最大值

# 查找最大值
max_calories=food_info['Energ_Kcal'].max()
print(max_calories)

4. 排序

# 排序    NAN是缺失值,都是放在最后的
food_info.sort_values('Sodium_(mg)',inplace=True) #对Sodium_(mg)这一列进行从小到大排序,并生成一个新的dataframe
print(food_info)
food_info.sort_values('Sodium_(mg)',inplace=True,ascending=False) #关闭升序,相当于进行从大到小

5. 实例:泰坦尼克竞赛那题

(1)判断元素是否为空,计算为空的个数

import numpy as np
import pandas as pd

titanic_survival=pd.read_csv('titanic_train.csv')
print(titanic_survival.head(3))

# pandas.isnull() 用于元素判断为空
age=titanic_survival['Age'] #访问Age这一列
age_is_null=pd.isnull(age) #逐一判断是否为空
# print(age_is_null) #输出就是false/true,告诉你哪个为空
age_null_true=age[age_is_null] #把true的部分提取出来,赋值给age_null_true
# print(age_null_true)
print('为空的数目:'+str(len(age_null_true))) #177
# 删去为空的记录
drop_na_column=titanic_survival.dropna(axis=1)
new_titanic_survival=titanic_survival.dropna(axis=0,subset=['Age','Sex'])
print(new_titanic_survival)

(2)计算平均值(错误范例,按类别计算平均值。。)

# 计算平均值
# 错误计算,把空值也包括进去
mean_age=sum(titanic_survival['Age'])/len(titanic_survival['Age'])
print(mean_age) #nan

# 正确
good_age=titanic_survival["Age"][age_is_null==False] #!!!将Age这一列中,非空的行取出来,放在good_age中
correct_mean_age=sum(good_age)/len(good_age)
print(correct_mean_age) #29.69911764705882

# 更加简便的方式,mean()函数
# 然而这种方式将缺失值直接删去的
correct_mean_age2=titanic_survival['Age'].mean()
print(correct_mean_age2) #29.69911764705882
分别求每个舱位的平均价格
# 分别求每个舱位的平均价格
passager_classes=[1,2,3]
fares_by_class={}
for this_class in passager_classes:
    pclass_rows=titanic_survival[titanic_survival['Pclass']==this_class] #将某一舱位的所有乘客信息存在pclass_rows中
    pclass_fares=pclass_rows['Fare'] #将这一舱位的所有价格提取出来,存在pclass_fares中
    fare_for_class=pclass_fares.mean() #计算平均值
    fares_by_class[this_class]=fare_for_class #在存储‘舱位-价格’的字典中,添加数据
print(fares_by_class) #{1: 84.1546875, 2: 20.662183152173913, 3: 13.675550101832993}

# 更加便捷的方式!!!
fares_by_class2=titanic_survival.pivot_table(index='Pclass', values='Fare',aggfunc=np.mean) #默认是进行平均计算
print(fares_by_class2)

port_stats=titanic_survival.pivot_table(index='Embarked',values=['Fare','Survived'],aggfunc=np.sum)
print(port_stats) #强化练习:按港口售出的船票总价和获救人数

(3)定位到具体的一个数据项

# 定位到一个具体的值
row_index_83_age=titanic_survival.loc[83,'Age'] #索引83,所以是第84条记录处的年龄
print(row_index_83_age)

(4)排序

#排序
new_titanic_survival=titanic_survival.sort_values('Age',ascending=False) #对年龄这一列进行降序排列
print(new_titanic_survival.head(10))
titanic_reindexed=new_titanic_survival.reset_index(drop=True) #重新排序
print(titanic_reindexed)

(5)自定义函数

# 自定义函数操作apply
# 自定义的一个函数,返回某dataframe的第99行
def hundred_row(column):
    hundredth_item=column[99]
    return hundredth_item

hundredth_row=titanic_survival.apply(hundred_row)
print(hundredth_row)

# 例2:计算每个列的缺失值并输出,这个有一点点不理解,先记着
def null_count(column):
    column_null=pd.isnull(column)
    null=column[column_null]
    return len(null)
column_null_count=titanic_survival.apply(null_count)
print(column_null_count)

(6)其他:通过set_index函数可以设置其他index,可以是字符串,但同时,数字的索引还是可以用的

 

三、Series结构

1. 含义:series can be regarded as a collection of values, 而 DataFrame ——collection of Series objects

    pandas内部定义的,DataFrame相当于数据读进来之后的那个矩阵,Series就是一行或者一列

2. 操作

(1)读取csv文件,将其中某列读取为series格式,观察

import numpy as np
import pandas as pd
from pandas import Series

fandango=pd.read_csv('fandango_score_comparison.csv')
series_film=fandango['FILM']
print(type(series_film)) #<class 'pandas.core.series.Series'>
print(series_film[0:5]) # 输出前5条记录的电影名称

film_name=series_film.values #把电影名全部赋值给film_name
print(film_name)
print(type(film_name)) #<class 'numpy.ndarray'>,所以说,建立在numpy的基础之上呀

(2)series的特殊操作:将两个相同维度的series合并为一个大的series,并指定一个作为index

series_rt=fandango['RottenTomatoes']
rt_scores=series_rt.values
series_custom=Series(rt_scores,index=film_name) #将RT这个电影院的分数和电影的名称这两列(series)组成一个大的series,像一个矩阵一样,其中index是电影名称
print(series_custom[['The Lazarus Effect (2015)','Phoenix (2015)']])
#此时,数字索引同样可以用
print(series_custom[0:3])
# print(type(series_custom)) #<class 'pandas.core.series.Series'>

(3)排序(用得少)

# 排序
original_index=series_custom.index.tolist()
sorted_index=sorted(original_index)  #重新排序,按字母的顺序排序
sorted_by_index=series_custom.reindex(sorted_index)
print(sorted_by_index)

(4)运算,一个series的计算,两个series相同index可进行计算

# 运算
print(np.add(series_custom,series_custom))
print(np.sin(series_custom))
print(np.max(series_custom))

series_custom_greater_than_60=series_custom[series_custom>60]
print(series_custom_greater_than_60)

#两个series的index相同的时候,对象项可以相加减
rt_cri=Series(fandango['RottenTomatoes'].values,index=fandango['FILM'])
rt_users=Series(fandango['RottenTomatoes_User'].values,index=fandango['FILM'])
rt_mean=(rt_cri+rt_users)/2
print(rt_mean)

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Pandas是一个Python,用于数据处理和分析。在数据分析中,预处理是非常重要的一步,因为它可以帮助我们清洗和转换数据,使其更适合进行分析。Pandas提供了一些强大的预处理功能,包括数据清洗、数据转换、数据重塑和数据合并等。在使用Pandas进行数据分析时,预处理是必不可少的一步。 ### 回答2: 在数据分析中,数据的预处理是一个必要的过程。它的主要目的是清洗数据,准备数据,以便后续分析。在Python中,pandas是一种广泛使用的数据处理pandas可以通过其高效的数据结构和操作方法来清洗和处理数据。在本文中,将介绍pandas预处理的一些常见技术。 一、读取数据 在pandas中,使用read_csv()函数读取CSV格式的数据文件,read_excel()函数读取Excel格式的数据文件。它们都有很多选项,可以根据具体文件的格式进行设置。 二、查看数据 在pandas中,使用以下函数来查看数据: 1. head() - 显示数据框的前几行; 2. tail() - 显示数据框的后几行; 3. columns - 显示数据框的列名; 4. shape - 显示数据框的行列数; 5. info() - 显示数据框的基本信息,包括每列的名称、非空值数量和数据类型。 三、数据清洗 在数据清洗中,有以下一些常见的技术: 1. 删除重复行:使用drop_duplicates()函数; 2. 替换空值:使用fillna()函数; 3. 删除空值:使用dropna()函数; 4. 更改数据类型:使用astype()函数。 四、数据准备 在数据准备中,有以下一些常见的技术: 1. 数据合并:使用merge()函数; 2. 数据筛选:使用loc()函数或者iloc()函数; 3. 数据分组:使用groupby()函数; 4. 数据排序:使用sort_values()函数。 五、数据分析 在数据分析中,有以下一些常见的技术: 1. 数据聚合:使用agg()函数; 2. 统计描述:使用describe()函数; 3. 数据可视化:使用matplotlib或者seaborn。 综上所述,pandas预处理是数据分析中必不可少的一步。通过使用pandas提供的函数和方法,可以方便地清理和处理数据,使其更容易被分析。 ### 回答3: PandasPython中最强大的数据处理之一,它提供了DataFrame和Series这两种数据结构,可以快速便捷地处理数据。在数据分析过程中,我们往往需要先对数据进行预处理,以便后续的分析。Pandas提供了一系列的方法和函数,可以帮助我们进行数据的预处理。 首先,在进行数据分析之前,我们需要了解自己所面对的数据类型和数据结构。Pandas中的DataFrame结构就是类似于表格的结构,每一行代表一个样本,每一列代表一个属性。Series则是一维的数组结构。通过pandas.read_csv(),我们可以读取CSV格式的数据,并转化为DataFrame结构。 接下来,我们要对数据进行一些基本的处理,例如数据清洗、数据去重、缺失值处理、异常值处理等。在数据清洗过程中,我们往往需要对数据进行一些特殊的处理,例如字符串的分割、合并、替换等操作,Pandas提供了一系列能够对文本进行操作的函数。在数据去重方面,我们可以使用drop_duplicates()函数,它可以去除DataFrame中的重复记录。在处理缺失值时,Pandas提供了一系列的函数,如fillna()函数、dropna()函数,可以方便地将NaN值变为其他有意义的值,或者删除缺失值的行或列。在异常值处理方面,我们可以使用isoutlier()函数来找到数据中的异常值,并进行处理。 在数据预处理完成后,我们可以对数据进行一些统计分析,例如计算小计、计算总计、分位数、极差、方差、标准差等统计指标。我们可以使用describe()函数来获得数据的统计描述,还可以使用groupby()函数来对数据分组,使用agg()函数对每组进行计算统计指标。此外,我们还可以对数据进行排序、丢弃、合并等操作。 总之,Pandas是一个非常强大的Python,可以轻松处理数据预处理和数据处理方面的任务。Pandas作为数据分析和数据处理的基础,使用熟练后可以在数据分析中发挥更大的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值