官方调研重磅发布,Pandas或将重构?


原文地址:2019 Pandas User Survey

为指引 Pandas 未来开发方向,Pandas 官方团队于 2019 年夏搞了一次调研,这次调研历时 15 天,共有 1250 条反馈数据。问卷数据保存在 data 文件夹的 2019.csv.zip 文件里。

这里又学一招,原来 pandas 可以直接从压缩文件里读取数据文件,原文用的是 .gz 文件,呆鸟这里用 .zip 也可以。

下列代码读取问卷数据,并对 matplotlib、seaborn 的字体进行设置,其中还包括了,如何在 macOS 里显示中文。

import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt

%matplotlib inline

plt.rcParams['figure.dpi'] = 150

# 让 matplotlib 支持中文
plt.rcParams['font.sans-serif'] = ['SimHei']

# 让 seaborn 的文字大一些
sns.set( font='SimHei', font_scale=1.2)

# # 让 MacOS 下的 Matplotlib 与 Seaborn 支持中文
# plt.rcParams['font.family'] = ['Arial Unicode MS']
# sns.set_style('whitegrid',{'font.sans-serif':['Arial Unicode MS','Arial']})


# 用来正常显示负号,这里其实用不上
plt.rcParams['axes.unicode_minus'] = False

df = pd.read_csv("data/2019.csv.zip", parse_dates=['日期时间'], encoding="GBK")

# df.head()

答卷人分析

绝大多数答卷人都具有丰富的 pandas 使用经验,使用频率也很高。

order = [
    '少于 3 个月',
    '3 个月 至 1 年',
    '1 至 2 年',
    '3 至 5 年',
    '5 年以上',
]

sns.countplot(y='您用 pandas 多久了?',
              data=df, order=order,
              color='k').set(title="您用 pandas 多久了?",
                             ylabel="")
sns.despine()


order = [
    "刚开始用",
    "偶尔",
    "每周",
    "每天"
]

sns.countplot(y='pandas 使用频率', data=df, order=order,
              color='k').set(title="pandas 使用频率",
                             ylabel="")
sns.despine()


为了对比 Pandas 与 Python 的流行度,我们的问卷里提出了一些 Python 开发者调研问卷问过的问题。

90% 的答卷人把 Python 作为主开发语言,Python 软件基金会调研报告里的数据为 84%。

pct_format = "{:0.2%}".format

df['Python 是您的主打语言吗?'].str.replace(
    "否.*", "否").value_counts(normalize=True).apply(pct_format)

是    90.67%
否     9.33%
Name: Python 是您的主打语言吗?, dtype: object

数据显示 Windows 用户居多。

oses = [
    "Linux",
    "Windows",
    "MacOS"
]
df['您用哪种操作系统?'].str.split(';').explode().value_counts().div(
    len(df)).loc[oses].apply(pct_format)
Linux      61.57%
Windows    60.21%
MacOS      42.75%
Name: 您用哪种操作系统?, dtype: object

这里用 0.25 版推出的 explode 方法定义了个函数。

def split_and_explode(s):
    return s.str.split(";").explode().to_frame()

conda 是最流行的虚拟环境工具。

def split_and_explode(s):
    return s.str.split(";").explode().to_frame()

conda 是最流行的虚拟环境工具。

replace = {
    "否,我不用虚拟环境": "否"
}

col = '您是否用过下列 Python 虚拟环境工具?(多选)'

sns.countplot(y=col,
              data=split_and_explode(df[col]).replace(replace),
              color='k').set(title='您是否用过下列 Python 虚拟环境工具?',
                             ylabel="")
sns.despine()


绝大多数答卷人只用 Python 3。

df['Python 2 还是 3?'].value_counts(normalize=True).rename(
    index={"2;3": "2 & 3"}).apply(pct_format)

3        92.39%
2 & 3     6.80%
2         0.81%
Name: Python 2 还是 3?, dtype: object

Pandas API

开源软件团队很难了解用户实际爱用哪些功能,这次调研,我们特地提了一些问题,了解了大家的喜好。

CSV 与 Excel 是最流行的文件类型,真是让人喜忧参半。

sns.countplot(y='您常用哪个读写器读取数据?',
              data=df['您常用哪个读写器读取数据?'].str.split(';').explode().to_frame(),
              color='k').set(title="您常用哪个读写器读取数据?",
                             ylabel="")
sns.despine();


为了做好重构 pandas 内核的准备,我们还调研了 100 列及以上大型 DataFrame 的处理情况。

sns.countplot(y='处理 100 列及以上大型 DataFrame 的频率',
              data=df, color='k').set(title="处理大型 DataFrame 的频率",
                                      ylabel="");
sns.despine()


Pandas 增加新扩展类型的速度较慢。类别型(Categorical)是最常用的,此外,可空整数(Nullable Integer)与带时区的 Datetime 也很常用。

sns.countplot(y='您常用的扩展数据类型是什么?',
              data=split_and_explode(df['您常用的扩展数据类型是什么?']),
              color='k').set(title="您常用的扩展数据类型是什么?",
                             ylabel="")
sns.despine();


我们还提出了一些问题,用以了解用户最想要的功能。

sns.countplot(y='您现在最想看到的改进是什么?',
              data=df,
              color='k').set(title="您现在最想看到的改进是什么?",
                             ylabel="")
sns.despine()


common = (df[df.columns[df.columns.str.startswith("迫切想要的功能")]]
          .rename(columns=lambda x: x.lstrip("迫切想要的功能  [").rstrip(r"]")))

counts = (
    common.apply(pd.value_counts)
    .T.stack().reset_index()
    .rename(columns={'level_0': '问题', 'level_1': "重要程度", 0: "关注数量"})
)

order = ["无关紧要", "还算有用", '至关重要']
g = (
    sns.FacetGrid(counts, col="问题", col_wrap=2,
                  aspect=1.5, sharex=False, height=3)
    .map(sns.barplot, "重要程度", "关注数量", order=order)
)


一眼就能看出来,优化大规模数据集的处理能力是大家最想要的,从此图还能观测出:

  1. Pandas 文档应该加大力度推广处理大规模数据集的支持库,如 Dask, vaex、 modin。

  2. 从对原生字符串数据类型与更少的内部复制需求来看,优化内存效率也是要值得一做的事情。

紧接其后的优化需求是整数缺失值,这个功能其实已经在 Pandas 0.24 时已经推出了,但还不是默认方式,与其它 pandas API 的兼容性也有待优化。

与 NumPy 相比,pandas 略显激进。在即将推出 1.0 版里,我们将废弃很多功能,并对很多 API 进行翻天覆地的改变,好在大部分人都能接受这样的改变。

df['Pandas 能满足您的需求吗'].value_counts(normalize=True).apply(pct_format)

是    94.89%
否     5.11%
Name: Pandas 能满足您的需求吗, dtype: object

不少人,甚至 pandas 维护人员都觉得 pandas API 的规模太大了。为了量化这个问题,我们还向用户提出了关于 pandas API 规模的问题,看看大家觉得是太大,还是太小,还是刚刚好。

renamer = {"pandas 接口太大了(难找到要用的方法或难记)还是太小了(需要提供更多功能)": "pandas 接口太大吗?"}
sns.countplot(y="pandas 接口太大吗?",
              data=df.rename(columns=renamer),
              color='k').set(title="pandas 接口太大吗?",
                             ylabel="")
sns.despine();


最后,我们还提出了满意度的问题,从 1 (非常不满意)至 5 (非常满意)。

sns.countplot(y='Pandas 满意度',
              data=df[['Pandas 满意度']].dropna().astype(int),
              color='k').set(title="Pandas 满意度",
                             ylabel="")
sns.despine();


大多数人都对 pandas 非常满意。满意度的平均分为 4.39。我们希望以后能跟踪这一数据的变化。

呆鸟云:“pandas 团队真有创意,一边做调研,一边教大家 pandas,呆鸟我也算学了不少东西,建议大家也亲自动手实现一下,在呆鸟公众号里,发送 “pandas调研”,就可以获取中文版的 ipynb 文件与数据集下载地址了。”

零基础学 Python,来这里

只需7天时间,跨进Python编程大门,已有3800+加入

【基础】0基础入门python,24小时有人快速解答问题;
【提高】40多个项目实战,老手可以从真实场景中学习python;
【直播】不定期直播项目案例讲解,手把手教你如何分析项目;
【分享】优质python学习资料分享,让你在最短时间获得有价值的学习资源;圈友优质资料或学习分享,会不时给予赞赏支持,希望每个优质圈友既能赚回加入费用,也能快速成长,并享受分享与帮助他人的乐趣。
【人脉】收获一群志同道合的朋友,并且都是python从业者
【价格】本着布道思想,只需 69元 加入一个能保证学习效果的良心圈子。

【赠予】后续圈主将开发python,0基础入门在线课程,免费送给圈友们,供巩固和系统化复习

(三重福利)最近入圈送大礼包:

1、2.7G、308份最新数据分析报告
2、40G 人工智能算法  视频课
3、Python爬虫课,共14课


更多精彩

在公众号后台对话框输入以下关键词

查看更多优质内容!

PM2.5 | 世界杯 | 惊喜 | 附书代码

觉得不错,请把这篇文章分享给你的朋友

转载 / 投稿请联系:data_circle_yoni

● 总结 Python 的4张超大思维导图,一定不要错过哦

 知乎13万赞!为何很多名校毕业生,都输在了人生后半程

 【连载】小白轻松学Python ---- 到底如何入门  Python?

● 怎么才能自学成 Python 大牛?这有些建议

 Python打牢基础,从22个语法开始!

 手把手 | 爬取京东评论,且修改网址直接可复用哦(送代码)

● 为何“Python 之父” 力荐的小蓝书火了?

 Python实战 | 只需 ”三步“ 爬取二手iphone手机信息(转发送源码)

 做数据分析不得不看的书有哪些?

 Python实战 | 手把手教你爬取豆瓣电影 Top 250

发布了88 篇原创文章 · 获赞 18 · 访问量 11万+

猜你喜欢

转载自blog.csdn.net/lovenankai/article/details/103607377