Python对全球Covid-19疫情失业数据相关性、可视化分析

“失业”是 Covid-19 疫情的许多负面影响之一,几乎每个国家都受到了影响

由Kaizong Ye,Liao Bao撰写

帮助客户研究 Covid-19 期间的失业情况可能不仅揭示了该疫情对每个国家的影响程度,还揭示了世界各地不同的裁员文化。

在一个经济体中辞退工人的决策中有哪些因素?根据《商业内幕》(Business Insider)的报道,文化扮演着至关重要的角色。

× 衡量劳动力市场紧张程度的指标有很多,例如就业率、失业率、职位空缺率、职位空缺/失业人数。约三分之二的发达经济体的就业已经修复到甚至超越疫情前的水平,达到二十年以来的低点。甚至一些以高失业率著称的国家如希腊,失业率也出现大幅下降。 来源:OECD,银科金融研究院,季度数据 对很多国家来说,更严峻的问题是,尽管劳动力不断返回市场,仍然面临就业市场紧张和广泛的劳动力短缺问题,令原本就粘性的通胀问题更加棘手。 美国街头随处可见无人问津的招聘广告牌,仓储、餐厅、销售、邮政,几乎各行各业都苦于招工难题。 在德国和法国,技术工岗位尤其是与制造业、数字化转型有关的职位空缺更为显著,在加拿大和澳洲,餐饮服务业的缺工最明显,不少餐厅甚至开出了高额时薪的招聘广告。 在疫情以前,失业率一直是衡量劳动力市场松紧程度的最常用的指标。但近两年来,更多的研究显示,使用职位空缺率(V)与失业率(U)的比例(V/U)来衡量劳动力市场的紧张程度,可能更为合适。 从职位空缺/失业人数比例来看,几乎所有国家的劳动力紧俏程度都较疫情前更高,仅有日本、瑞士和部分东欧国家例外。加拿大、英国、澳大利亚的职位空缺/失业人数比例都高达2019年末的两倍之多,美国这一比例更达到1960年来最高水平。

德国公司必须设立工厂委员会——代表工人在执行委员会面前发言的员工——以寻求解雇替代方案。

瑞典有计划帮助重新培训被解雇的员工,并为他们提供慷慨的失业救济金。而在像日本这样有关职业保障的长期传统国家,裁员甚至被认为是一种社会禁忌。

除了失业外,该研究还旨在调查数据集提供的与就业有关的其他因素,例如劳动力依赖比和男女就业比率。

调查问题:

  1. 哪些国家和地区失去的工作小时数百分比最高和最低?
  2. 收入水平和失业率之间是否存在相关性?
  3. 哪些国家和地区劳动力依赖比最高和最低?
  4. 失去的工作小时数和劳动力依赖比之间是否存在相关性?
  5. 哪些国家和地区的男女劳动力就业比率最高和最低?

数据集

以 cvs 形式获取的数据。

image.png

大多数估计值来自 2020 年。数据集包括以下信息:


  • 就业人员的总每周工作时间
  • 相对于基线(2019 年第四季度)失去的小时数百分比
  • 相对于基线(2019 年第四季度)失去的小时数百分比,以全职就业损失表示。该指标通过将因 Covid-19 而失去的每周工时数除以 40 得到。
  • 相对于基线(2019 年第四季度)失去的小时数百分比,以全职就业损失表示。该指标通过将因 Covid-19 而失去的每周工时数除以 48 得到。
  • 被赡养者(年龄为 0-14 岁的人 + 要么在劳动力外要么失业的 15 岁及以上的人)与总就业人数之间的比率。
  • 2019 年从事以下某一类别工作(无论是否在工作岗位上)的女性:a) 有薪就业;或 b) 自雇(无论是在工作还是在企业中,但不在工作中)。
  • 2019 年从事以下某一类别工作(无论是否在工作岗位上)的男性:a) 有薪就业;或 b) 自雇(无论是在工作还是在企业中,但不在工作中)。
  • 15-64 岁人口的总每周工作时间与总人口之间的比率。

理解数据

employment.head()
image.png

课程

R语言数据分析挖掘必知必会

从数据获取和清理开始,有目的的进行探索性分析与可视化。让数据从生涩的资料,摇身成为有温度的故事。

立即参加

employment.tail()
image.png
employment.info()
image.png
employment.isnull().sum()
image.png

图片

自然语言处理NLP:主题LDA、情感分析疫情下的新闻文本数据

阅读文章


employment.describe()
image.png


随时关注您喜欢的主题


分析

1. Covid-19期间失去的工作小时数

1.1. 概述

在[17]:# 添加一个包含三个字母ISO国家代码的列 import pycountry def findCountryAlpha3 (country_name): try: ...... # 创建一个显示Covid-19期间失去工作小时数百分比的世界地图 import matplotlib.pyplot as plt ...... color_continuous_scale=px.colors.sequential.Viridis) fig.show()

1.2. 失去工作小时数最高和最低的国家是哪些?

在[18]:# 失去工作小时数百分比最高的5个国家 employment.sort_values('percentage_of_working_hrs_lost', ......
image.png
# 失去工作小时数百分比最低的5个国家 employment ......
image.png
# 有多少个国家的失业率高于平均水平? lost_hours = employment['percen ......

世界上有 131 个国家的失业率高于平均水平。

1.3. 失业率与收入之间是否存在相关性

# 根据收入水平找到失业数据 high_income = ['World: High income', ...... "Northern, Southern and Western Europe: High income", ...... "Eastern Asia: Upper-middle income", "South-Eastern Asia and the Pacific: Upper-middle income", ...... lower_middle = ['World: Lower-middle income', "Africa: Lower-middle income", "Africa: Upper-middle ...... low_income = ['World: Low income', 'Africa: Low income', ...... "Central and Western Asia: Low income"] # 根据条件选择行: high = employment[employment['country'].isin(high_income)] ...... # 基于收入水平计算失去工作小时数的平均值: high_mean = round(high['p .......mean(), 2) ...... for income, avg in zip(income_types,avgs): ......
image.png

收入和失业时间的关系

In [22]:name_income = ['High','Upper-middle','Lower-middle','Low'] ...... plt.show()
image.png

2. 劳动力依赖

2.1. 概览

在[23]中:

# 创建劳动力依赖比例的世界地图
import matplotlib.pyplot as plt

fig = px.choropleth(employment, locations="alpha_3",
               
    ......
fig.show()

2.2. 工作流失和劳动力依赖的相关性

在[24]中:

# 最高/最低劳动力依赖国家的工作时间损失百分比是什么样子?

columns = 
    ......
employment1.head(5)
image.png
# 工作时间损失和劳动力依赖比例之间的相关性

ld_ratio = pd.Series(emplo
    ......tio"])

    ......

在[25]中:

-0.026

在[26]中:

# 工作时间损失和劳动力依赖比例之间的关系图

ld_ratio = employment["labour
    ......
plt.show()
image.png

3. 就业性别比例

3.1. 概述

在[27]中的代码是用来计算全球范围内女性就业人数与男性就业人数的比例,并将结果可视化。

pythonCopy Code
# 计算全球范围内女性就业人数与男性就业人数的比例
import numpy as np

female = np.array(empl
        ......
employment['gender_difference'] = gender_diff

# 哪些国家的女性劳动力参与度最高和最低?
        ......round(gender_diff.mean(), 2),'%')
        ......

# 可视化全球范围内女性就业人数与男性就业人数的比例
import matplotlib.pyplot as plt


fig = px.choropleth(employment, locations="alpha_3",
        ......
                    color_contsma)
fig.show()
image.png

3.2. 比较不同地区男女劳动力参与度

在[28]中的代码是用来计算不同地区的女性劳动力参与度与男性劳动力参与度的比例,并进行了可视化。

# 计算不同地区的性别差异

female = np.array(employment['employed_female_25+_2019'])
        ......

region_group = employment[employment['country'].isin(regions)]
        ......
region_group
image.png
# 比较不同地区男女劳动力参与度的柱状图


gender_diff = [73.3
        ......8971]

plt.bar(regions, gender_diff)
        ......
plt.show()
image.png

在[30]中的代码是使用T检验检查女性劳动力参与度是否与男性劳动力参与度存在显著差异。

#进行t检验以检查女性劳动参与率是否与男性劳动参与率有所不同
#零假设:女性的劳动参与率与男性的劳动参与率无差异。
#备择假设:女性和男性的劳动参与率存在差异。
#统计显著性水平为0.05。

f = employment['employed_female_25+_2019'
    ......
print('{0:0.3f}'.format(pval))

#通过p值0.105,我们不能拒绝零假设。
0.10

更多可视化

1. 相关矩阵

在[31]:

emplorr()
image.png
#使用seaborn热图绘制相关矩阵

sns.heatmap(empl
    ......square=True);
下载 (1).png
#创建失去工作小时数的直方图

employmet.hist(bins=15)
image.png
#计算每个地区每周工作小时数的比率

columns1 = ['country','rat
    ......olumns1)
region_group1
image.png
#创建每个地区每周工作小时数比率的图表

sns.barplot("country", 
    ......per region")

Out[35]:

[Text(0.5, 1.0, 'Working hours per region')]
image.png

结论

  • 在疫情期间,全世界的国家都面临就业不安全。失去工作时间的平均比率约为9%。不同国家和地区的影响有所不同,有些国家像新西兰或芬兰遭受的损失很小,而南美洲的一些国家面临着高达27.5%的惊人失业率。
  • 收入和失业的关系不明确,需要深入研究。虽然收入水平较高的地区比中高收入和中低收入地区承受的失业量少,但低收入地区的失业时间最少。
  • 拥有最高劳动力依赖比例的国家位于非洲。尽管劳动力依赖率最高的国家也有较高的失业率,但统计数据表明,劳动力依赖性与失业关系不显著。
  • 平均而言,2019年劳动力市场女性占男性的七分之五。欧洲在劳动力市场性别平等方面继续领先。


可下载资源

关于作者

Kaizong Ye拓端研究室(TRL)的研究员。Kaizong Ye拓端研究室(TRL)的研究员。在此对他对本文所作的贡献表示诚挚感谢,他在上海财经大学完成了统计学专业的硕士学位,专注人工智能领域。擅长Python.Matlab仿真、视觉处理、神经网络、数据分析。

本文借鉴了作者最近为《R语言数据分析挖掘必知必会 》课堂做的准备。

​非常感谢您阅读本文,如需帮助请联系我们!

 
QQ在线咨询
售前咨询热线
15121130882
售后咨询热线
0571-63341498

关注有关新文章的微信公众号


永远不要错过任何见解。当新文章发表时,我们会通过微信公众号向您推送。

技术干货

最新洞察

This will close in 0 seconds