假设有一购房数据表,其中学历数据有“高中及以下”、“大专/高职”、“大学本科”三类,限购政策数据有“作用不大”、“有一定作用”、“有明显作用”三类,请用Python制作堆积柱状图,探究不同学历对限购政策的观点是否有所不同

时间: 2023-10-17 16:05:15 浏览: 39
好的,以下是Python代码实现堆积柱状图的方法: 首先,我们需要导入几个必要的库:pandas, matplotlib.pyplot, numpy。pandas用于读取数据,matplotlib.pyplot用于绘图,numpy用于生成随机数据。 ```python import pandas as pd import matplotlib.pyplot as plt import numpy as np ``` 然后,我们需要读取数据表并进行预处理。假设数据表的文件名为data.csv,其中包含两列数据:学历和限购政策。我们可以使用pandas库中的read_csv函数读取数据,并使用crosstab函数生成交叉表,其中行为学历类别,列为限购政策类别,值为统计数值。 ```python data = pd.read_csv('data.csv') table = pd.crosstab(data['学历'], data['限购政策']) ``` 接下来,我们需要将交叉表转换为堆积柱状图的数据格式。我们可以使用numpy库中的cumsum函数将每一列的值逐行累加,得到一个新的二维数组。 ```python stacked_data = np.cumsum(table, axis=1) ``` 最后,我们可以使用matplotlib.pyplot库中的bar函数绘制堆积柱状图。需要注意的是,我们需要为每一个类别绘制一条竖直的线,以区分不同的类别。 ```python plt.bar(table.index, table.iloc[:,0], color='b') plt.bar(table.index, table.iloc[:,1], bottom=stacked_data.iloc[:,0], color='g') plt.bar(table.index, table.iloc[:,2], bottom=stacked_data.iloc[:,1], color='r') plt.legend(['作用不大', '有一定作用', '有明显作用']) plt.xlabel('学历') plt.ylabel('数量') plt.title('不同学历对限购政策的观点') plt.show() ``` 完整代码如下: ```python import pandas as pd import matplotlib.pyplot as plt import numpy as np data = pd.read_csv('data.csv') table = pd.crosstab(data['学历'], data['限购政策']) stacked_data = np.cumsum(table, axis=1) plt.bar(table.index, table.iloc[:,0], color='b') plt.bar(table.index, table.iloc[:,1], bottom=stacked_data.iloc[:,0], color='g') plt.bar(table.index, table.iloc[:,2], bottom=stacked_data.iloc[:,1], color='r') plt.legend(['作用不大', '有一定作用', '有明显作用']) plt.xlabel('学历') plt.ylabel('数量') plt.title('不同学历对限购政策的观点') plt.show() ``` 以上代码将生成一张堆积柱状图,横轴为学历类别,纵轴为数量,颜色区分不同的限购政策类别。您可以根据需要对代码进行修改和调整。

相关推荐

最新推荐

recommend-type

第四届 蓝桥杯 竞赛试题题目 C/C++高职高专组

C/C++高职高专组 1、题目标题: 猜年龄 美国数学家维纳(N.Wiener)智力早熟,11岁就上了大学。他曾在1935~1936年应邀来中国清华大学讲学。 一次,他参加某个重要会议,年轻的脸孔引人注目。于是有人询问他的年龄...
recommend-type

2017 年全国职业院校信息安全管理与评估大赛高职组_第一阶段任务二答案及评分标准(2)

信息安全管理与评估 2017 年全国职业院校信息安全管理与评估大赛高职组_第一阶段任务二答案及评分标准(2)
recommend-type

《数据备份与灾难恢复技术》课程标准

《数据备份与灾难恢复技术》是高职信息安全专业的一门专业主干课课程,是学生必修、考试课程,属于理论与实践紧密结合的课程。理论教学以使学生掌握专业基本知识、基本方法为度,实际数据备份与灾难恢复技术案例贯穿...
recommend-type

2019年重庆市职业院校技能大赛高职组“技能大赛”赛项竞赛样题A

2019年重庆市职业院校技能大赛高职组“技能大赛”赛项竞赛样题A,某企业计划搭建...按照给出的云平台架构进行IaaS、PaaS、大数据系统部署及运维管理,并进行大数据分析应用开发和微信小程序开发,最后提交工程文档。
recommend-type

2019年全国职业院校技能大赛高职组计算机网络应用竞赛试题

2019年全国职业院校技能大赛高职组计算机网络应用竞赛试题 包含: 1、2019年全国职业技能大赛高职组计算机网络应用赛项H卷.docx
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。