Python 数据分析之 3 —— pandas 数据分析

第1关:了解数据集特征

任务描述

本关任务:载入网贷数据集,了解数据概况。 共包含多个子任务: 1.1 读取Training_Master.csv文件,命名为master; 1.2 读取Training_Userupdate.csv文件,命名为user; 1.3 读取Training_LogInfo.csv文件,命名为log; 1.4 分别输出它们的形状; 1.5 输出包含master7个列名的列表; 1.6 输出user表的前3行。

知识讲解

为了完成本关任务,你需要掌握:

1.pandas模块导入
 
  1. import pandas as pd
2.pandas模块下的数据文件读取方法
 
  1. read_csv()
  2. #返回DataFrame类型对象

若数据包含中文,需添加参数encoding='gbk'

3.了解数据集基本特征的方法。
 
  1. DataFrame.shape #DataFrame形状
  2. DataFrame.head(n) #DataFrame数据的前n行
  3. DataFrame.columns #DataFrame的列索引
编程要求

根据提示,在右侧编辑器补充代码。

# -*- coding: utf-8 -*-

'''
第1关:了解数据集特征
'''
import pandas as pd
# 1.1 读取Training_Master.csv文件,命名为master。
############begin############

master = pd.read_csv("Training_Master.csv",encoding = "gbk")

#############end#############

#    1.2 读取Training_Userupdate.csv文件,命名为user。
############begin############

user = pd.read_csv("Training_Userupdate.csv",encoding = "gbk")

#############end#############

# 1.3 读取Training_LogInfo.csv文件,命名为log。
############begin############
log = pd.read_csv("Training_LogInfo.csv",encoding = "gbk")


#############end#############

# 1.4 分别输出它们的形状。
############begin############
print(master.shape)
print(user.shape)
print(log.shape)


#############end#############

# 1.5 输出包含master后7个列名的列表。
############begin############
print(list(master.columns)[-7:])


#############end#############

# 1.6 输出user表的前3行。
############begin############

print(user.head(3))

#############end#############



第2关:DataFrame 的 CRUD

任务描述

本关任务:使用DataFrame结构深入了解数据集细节。 包含4个子任务: 2.1 查询master表的列名前缀; 2.2 删除master表的列; 2.3 在master表中增加列; 2.4 修改master表数据。

知识讲解

为了完成本关任务,你需要掌握:

获取DataFrame列名

DataFrame.columns 返回DataFrame的列名Index对象

例如:

 
  1. In [1]: log.columns
  2. Out[1]: Index(['Idx', 'Listinginfo1', 'LogInfo1', 'LogInfo2', 'LogInfo3'], dtype='object')
字符串分割

str.split(分隔符) 返回字符串列表

例如:

 
  1. In [2]:'SocialNetwork_12'.split('_')
  2. Out[2]: ['SocialNetwork', '12']
删除DataFrame的列

根据索引名称(label)删除指定的行(axis = 0)或列(axis = 1),inplace指定是否删除原数据。 label可以是字符串,也可以是字符串列表。 DataFrame.drop(label,axis,inplace)

Series的广播操作

ndarray结构一样,Series结构也支持广播操作。

根据行列索引名称查询DataFrame

loc方法的参数很灵活,名称、名称列表、条件表达式均可,需根据实际情况灵活使用。条件表达式本质上仍是索引名列表。 DataFrame.loc[行索引名或条件表达式,列索引名或条件表达式]

编程要求

根据提示,在右侧编辑器补充代码。

# -*- coding: utf-8 -*-
'''
第2关:DataFrame的CRUD
'''
import pandas as pd

master = pd.read_csv("Training_Master.csv",encoding='gbk')
user = pd.read_csv("Training_Userupdate.csv",encoding='gbk')
log = pd.read_csv("Training_LogInfo.csv",encoding='gbk')

#    2.1 求取master表的列名前缀列表,并按字母升序输出该列表。
#     例如:SocialNetwork_12列的列名前缀为:SocialNetwork
############begin############

master_prefix_list = []
for s in master.columns:
    master_prefix_list.append(s.split("_")[0])
master_prefix_list = list(set(master_prefix_list))
master_prefix_list.sort()
print(master_prefix_list)

#############end#############

#    2.2 删除master中列名前缀为:SocialNetwork的列
#     输出:共**列被删除。
############begin############
cols_drop = [col for col in master.columns if col.startswith("SocialNetwork")]
n = len(cols_drop)
master = master.drop(columns=cols_drop)
print("共%d列被删除。"%n)



#############end#############

#    2.3在master表最右侧增加一列Result,
#    记录UserInfo_1和UserInfo_3的和,
#    并输出这三列的前5行。
############begin############
master["Result"] = master["UserInfo_1"]+master["UserInfo_3"]
print(master[["UserInfo_1","UserInfo_3","Result"]].head(5))

#############end#############

#    2.4将UserInfo_2列中所有的“深圳”替换为“中国深圳”,
#    并计算“中国深圳”的用户数。
############begin############
master["UserInfo_2"] = master["UserInfo_2"].replace("深圳","中国深圳")
n = master["UserInfo_2"].value_counts().get('中国深圳',0)
print(n)

#############end#############

第3关 利用 pandas 实现数据统计分析

任务描述

本关任务:利用pandas进行数据统计分析。 本关共包含4个子任务: 3.1 用户来源地分析; 3.2 未登录用户分析; 3.3 用户活跃度分析; 3.4 用户活跃期分析。

具体任务内容详见代码注释。

知识讲解

为了完成本关任务,你需要掌握:

数据频数统计
 
  1. Series.value_counts()
  2. #返回Series类型数据,表达Series每个取值的出现次数。
简单数据统计
 
  1. DataFrame.agg(np中的简单统计方法)
  2. #按列统计,直接返回统计结果
时间字符串转换为时间类型数据
 
  1. pd.to_datetime(Series或DataFrame)
取时间数据的星期名称
 
  1. Timestamp.day_name()
数据分组
 
  1. DataFrame.groupby(列索引)
  2. #返回DataFrameGroupBy对象,
  3. DataFrameGroupBy.nunique()
  4. #分组对象的nunique方法直接返回每个分组中不重复值的个数。
编程要求

根据提示,在右侧编辑器补充代码。

# -*- coding: utf-8 -*-

'''
第3关:利用pandas实现数据统计分析
'''
import numpy as np
import pandas as pd

master = pd.read_csv("Training_Master.csv",encoding='gbk')
user = pd.read_csv("Training_Userupdate.csv",encoding='gbk')
log = pd.read_csv("Training_LogInfo.csv",encoding='gbk')

# 3.1用户来源地评价。
#    在master表中用value_counts方法实现按用户所在地(UserInfo_2)统计用户数,
#    并按照如下格式输出统计结果的前5项(其中为英文符号)
#    城市:(用户数)
############begin############
locations_and_counts = master["UserInfo_2"].value_counts()
for location,count in locations_and_counts.head(5).items():
    print(location+":"+"(%d)"%count)



#############end#############

#3.2 未登录用户分析。
#    结合master表和log表的内容,
#    求取从未登录的用户的数量,直接输出
############begin############

logUsers = set(log["Idx"])
allUsers = set(master["Idx"])
notLogUsers = allUsers-logUsers
print(len(notLogUsers))

#############end#############

#3.3 用户活跃度分析。
#    求取信息更新(user表)次数最多的用户的最早登录时间(LogInfo3)
#    输出用户Idx,更新次数,最早登录时间
############begin############
#print(user["ListingInfo1"].head(10))
#print(log.columns)
#print(user[""].value_counts())
#print(user["UserupdateInfo1"].value_counts())
maxLogUser = user.groupby("Idx").size().idxmax()
maxUpdateCounts = user.groupby("Idx").size().max()
earlistLogTime = log.loc[log["Idx"]== maxLogUser]["LogInfo3"].min()
print(str(maxLogUser)+" "+str(maxUpdateCounts)+" "+str(earlistLogTime))

#############end#############

# 3.4 用户活跃期分析。
#     给user表增加新列“weekday”,填入更新日期(UserupdateInfo2)相应的星期名称
#     用groupby和nunique方式实现
#     按星期名称统计用户更新人数(注意,是人数),并输出
############begin############

user["UserupdateInfo2"] = pd.to_datetime(user["UserupdateInfo2"])
#print(user["UserupdateInfo2"])
user["weekday"] = user["UserupdateInfo2"].dt.day_name()

result = user.groupby("weekday")['Idx'].nunique()
print(result)

#############end#############

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值