美国大选献金项目数据分析

需求

  • 加载数据
  • 查看数据的基本信息
  • 指定数据截取,将如下字段的数据进行提取,其他数据舍弃
    • cand_nm :候选人姓名
    • contbr_nm : 捐赠人姓名
    • contbr_st :捐赠人所在州
    • contbr_employer : 捐赠人所在公司
    • contbr_occupation : 捐赠人职业
    • contb_receipt_amt :捐赠数额(美元)
    • contb_receipt_dt : 捐款的日期
  • 对新数据进行总览,查看是否存在缺失数据
  • 用统计学指标快速描述数值型属性的概要。
  • 空值处理。可能因为忘记填写或者保密等等原因,相关字段出现了空值,将其填充为NOT PROVIDE
  • 异常值处理。将捐款金额<=0的数据删除
  • 新建一列为各个候选人所在党派party
  • 查看party这一列中有哪些不同的元素
  • 统计party列中各个元素出现次数
  • 查看各个党派收到的政治献金总数contb_receipt_amt
  • 查看具体每天各个党派收到的政治献金总数contb_receipt_amt
  • 将表中日期格式转换为’yyyy-mm-dd’。
  • 查看老兵(捐献者职业)DISABLED VETERAN主要支持谁

import pandas as pd
from pandas import DataFrame
import numpy as np

df = pd.read_csv(‘./usa_election.csv’)
df.head()
在这里插入图片描述
在这里插入图片描述

df = df[[‘cand_nm’,‘contbr_nm’,‘contbr_st’,‘contbr_employer’,‘contbr_occupation’,‘contb_receipt_amt’,‘contb_receipt_dt’]]
df.head(5)
在这里插入图片描述

#对新数据进行总览,查看是否存在缺失数据
df.info()
在这里插入图片描述

#用统计学指标快速描述数值型属性的概要。
df.describe() #默认情况下是对df中的数值型数据进行统计描述
在这里插入图片描述

#对非数值型数据进行统计描述
df[[‘cand_nm’,‘contbr_nm’,‘contbr_st’,‘contbr_employer’,‘contbr_occupation’,‘contb_receipt_dt’]].describe()
在这里插入图片描述

#空值处理。可能因为忘记填写或者保密等等原因,相关字段出现了空值,将其填充为NOT PROVIDE
df.fillna(value=‘NOT PROVIDE’,inplace=True)

#异常值处理。将捐款金额<=0的数据删除
df.loc[df[‘contb_receipt_amt’] <= 0] #获取了异常数据对应的行数据
indexs = df.loc[df[‘contb_receipt_amt’] <= 0].index #获取了异常数据对应的行索引
df.drop(index=indexs,inplace=True)

#新建一列为各个候选人所在党派party

#可以通过百度搜索,找到每一个候选人对应的党派
parties = {
‘Bachmann, Michelle’: ‘Republican’,
‘Romney, Mitt’: ‘Republican’,
‘Obama, Barack’: ‘Democrat’,
“Roemer, Charles E. ‘Buddy’ III”: ‘Reform’,
‘Pawlenty, Timothy’: ‘Republican’,
‘Johnson, Gary Earl’: ‘Libertarian’,
‘Paul, Ron’: ‘Republican’,
‘Santorum, Rick’: ‘Republican’,
‘Cain, Herman’: ‘Republican’,
‘Gingrich, Newt’: ‘Republican’,
‘McCotter, Thaddeus G’: ‘Republican’,
‘Huntsman, Jon’: ‘Republican’,
‘Perry, Rick’: ‘Republican’
}
df[‘party’] = df[‘cand_nm’].map(parties)

#查看party这一列中有哪些不同的元素
df[‘party’].unique()
array([‘Republican’, ‘Democrat’, ‘Reform’, ‘Libertarian’], dtype=object)
#统计party列中各个元素出现次数
df[‘party’].value_counts()
在这里插入图片描述

#查看各个党派收到的政治献金总数contb_receipt_amt
df.groupby(by=‘party’)[‘contb_receipt_amt’].sum()
在这里插入图片描述

#注意:在Series中调用一个reset_index()可以将其快速变为df表格的样式
df.groupby(by=‘party’)[‘contb_receipt_amt’].sum().reset_index()
在这里插入图片描述

df.pivot_table(index=‘party’,values=‘contb_receipt_amt’,aggfunc=‘sum’)
在这里插入图片描述

#查看具体每天各个党派收到的政治献金总数contb_receipt_amt
df.groupby(by=[‘contb_receipt_dt’,‘party’])[‘contb_receipt_amt’].sum()
在这里插入图片描述

ret = df.pivot_table(index=[‘contb_receipt_dt’,‘party’],values=‘contb_receipt_amt’,aggfunc=‘sum’)
ret
在这里插入图片描述

#将表中日期格式转换为’yyyy-mm-dd’。
months = {‘JAN’ : 1, ‘FEB’ : 2, ‘MAR’ : 3, ‘APR’ : 4, ‘MAY’ : 5, ‘JUN’ : 6,
‘JUL’ : 7, ‘AUG’ : 8, ‘SEP’ : 9, ‘OCT’: 10, ‘NOV’: 11, ‘DEC’ : 12}
def transform_date(d):
day,month,year = d.split(‘-’)
month = months[month]
return ‘20’+year+‘-’+str(month)+‘-’+day
df[‘contb_receipt_dt’] = df[‘contb_receipt_dt’].map(transform_date)

#查看老兵(捐献者职业)DISABLED VETERAN主要支持谁
data = df.loc[df[‘contbr_occupation’] == ‘DISABLED VETERAN’]#取出了老兵对应的行数据
#分析老兵给哪位候选人捐赠的金额是最多的
data.groupby(by=‘cand_nm’)[‘contb_receipt_amt’].sum().sort_values(ascending=False)
在这里插入图片描述

#分析老兵给哪位候选人捐赠的次数是最多的
#size用来统计每组数据的行数
data.groupby(by=‘cand_nm’).size().sort_values(ascending=False)
在这里插入图片描述
源文件和模拟测试源可在这里下载:
https://download.csdn.net/download/ak2111/89036112?spm=1001.2014.3001.5501
内容来自大数据分析课程。

相关推荐

  1. Python数据分析~~美食排行榜

    2024-03-27 09:58:04       21 阅读
  2. 数据分析简单项目总结

    2024-03-27 09:58:04       61 阅读
  3. 数据分析项目实战过程

    2024-03-27 09:58:04       41 阅读
  4. 人大数据库数据分析的方法和工具

    2024-03-27 09:58:04       33 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-27 09:58:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-27 09:58:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-27 09:58:04       82 阅读
  4. Python语言-面向对象

    2024-03-27 09:58:04       91 阅读

热门阅读

  1. ChatGPT革新:打造高质量学术论文

    2024-03-27 09:58:04       46 阅读
  2. HTTP和HTTPS的区别

    2024-03-27 09:58:04       40 阅读
  3. ChatGPT之道:AI与编程的完美融合

    2024-03-27 09:58:04       36 阅读
  4. 软件工程---软件设计模式和软件体系结构

    2024-03-27 09:58:04       48 阅读
  5. Node.js 的常用命令详解

    2024-03-27 09:58:04       37 阅读
  6. 一些常用的Node.js命令

    2024-03-27 09:58:04       44 阅读
  7. PHP记录日志

    2024-03-27 09:58:04       41 阅读
  8. vue响应式基础

    2024-03-27 09:58:04       37 阅读
  9. Netty空闲检测&Keepalive

    2024-03-27 09:58:04       38 阅读
  10. dijkstra算法及模板题

    2024-03-27 09:58:04       39 阅读
  11. pytorch | pytorch改变tensor维度的方法

    2024-03-27 09:58:04       41 阅读
  12. 前端学习-CSS基础-Day1

    2024-03-27 09:58:04       42 阅读
  13. leetcode88-Merge Sorted Array

    2024-03-27 09:58:04       40 阅读