作者:Norman Niemer

翻译:李润嘉

校对:李洁

本文约2000字,建议阅读10分钟。

本文为资深数据科学家常见的10个错误提供解决方案。

数据科学家是“比软件工程师更擅长统计学,比统计学家更擅长软件工程的人”。许多数据科学家都具有统计学背景,但是在软件工程方面的经验甚少。我是一名资深数据科学家,在Stackoverflow的python编程方面排名前1%,并与许多(初级)数据科学家共事。以下是我经常看到的10大常见错误,本文将为你相关解决方案:

  1. 不共享代码中引用的数据

  2. 对无法访问的路径进行硬编码

  3. 将代码与数据混合

  4. 在Git中和源码一起提交数据

  5. 编写函数而不是DAG

  6. 写for循环

  7. 不编写单元测试

  8. 不写代码说明文档

  9. 将数据保存为csv或pickle文件

  10. 使用jupyter notebook

1. 不共享代码中引用的数据


数据科学需要代码和数据。因此,为了让别人可以复现你的结果,他们需要能够访问到数据。道理很简单,但是很多人忘记分享他们代码中的数据。

import pandas as pd
df1 = pd.read_csv('file-i-dont-have.csv') # fails
do_stuff(df)


解决方案:使用d6tpipe(https://github.com/d6t/ d6tpipe)来共享你的代码中的数据文件、将其上传到S3/web/google驱动等,或者保存到数据库,以便于别人可以检索到文件(但是不要将其添加到git,原因见下文)。

2. 对无法访问的路径进行硬编码


与错误1相似,如果你对别人无法访问的路径进行硬编码,他们将无法运行你的代码,并且必须仔细查看代码来手动更改路径。令人崩溃!

import pandas as pd
df = pd.read_csv('/path/i-dont/have/data.csv') # fails
do_stuff(df)    # or
import os
os.chdir('c:\\Users\\yourname\\desktop\\python') # fails


解决方案:使用相对路径、全局路径配置变量或d6tpipe,使你的数据易于访问。

d6tpipe:

https://github.com/d6t/d6tpip

3. 将代码与数据混合


既然数据科学的代码中包含数据,为什么不把它们放到同一目录中?那样你还可以在其中保存图像、报告和其他垃圾。哎呀,真是一团糟!

├── data.csv
├── ingest.py
├── other-data.csv
├── output.png
├── report.html
└── run.py

解决方案:将你的目录进行分类,比如数据、报告、代码等。请参阅Cookiecutter Data Scienced6tflow项目模板[见#5],并使用#1中提到的工具来存储和共享数据。

Cookiecutter Data Science:

https://drivendata.github.io/cookiecutter-data-science/

d6tflow项目模板:

https://github.com/d6t/d6tflow-templat

4. 在Git中和源码一起提交数据


现在,大多数人对他们的代码使用版本控制(如果你不使用,那就是另外一个错误,请参阅git:https://git-scm.com/)。在尝试共享数据时,很容易将数据文件添加到版本控制中。当文件很小时是可以的,但是git并没有针对数据进行优化,尤其是大文件。

git add data.csv

解决方案:使用第1点中提到的工具来存储和共享数据。如果你真的希望对数据进行版本控制,请参阅 d6tpipeDVCGit大文件存储

d6tpipe:

https://github.com/d6t/d6tpipe

DVC:

https://dvc.org/

Git大文件存储:

https://git-lfs.github.com

5. 编写函数而不是DAG


关于数据部分已经够多了,现在来谈一谈实际的代码!在学习编程时最先学习的内容之一就是函数,数据科学代码通常由一系列线性运行的函数组成。

这会导致一些问题,请参阅“为什么你的机器学习代码可能不好的4个原因”

https://github.com/d6t/d6t-python/blob/master/blogs/reasons-why-bad-ml-code.rst

def process_data(data, parameter):  data = do_stuff(data)  data.to_pickle('data.pkl')    data = pd.read_csv('data.csv')
process_data(data)
df_train = pd.read_pickle(df_train)
model = sklearn.svm.SVC()
model.fit(df_train.iloc[:, :-1], df_train['y'])

解决方案:数据科学代码不是一系列线性连接的函数,而是一组具有依赖关系的任务集合。请使用d6tflowairflow

d6tflow:

https://github.com/d6t/d6tflow-template

airflow:

https://airflow.apache.org

6. 写for循环


与函数类似,for循环也是你学习编程时最初学习的内容。它们易于理解,但是运行缓慢且过于冗长,通常意味着你不了解矢量化的替代方案。

x = range(10)
avg = sum(x)/len(x); std = math.sqrt(sum((i-avg)**2 for i in x)/len(x));
zscore = [(i-avg)/std for x]
# should be: scipy.stats.zscore(x)
# or
groupavg = []
for i in df['g'].unique():
dfg = df[df[g']==i]
groupavg.append(dfg['g'].mean())
# should be: df.groupby('g').mean()

解决方案:Numpy,scipypandas为你需要for循环的情况提供了矢量化函数。

Numpy:

http://www.numpy.org/

scipy:

https://www.scipy.org/

pandas:

https://pandas.pydata.org

7. 不编写单元测试


随着数据、参数或用户输入的改变,你的代码可能会出现问题,有时你并没有注意到。这可能会导致糟糕的输出结果,而如果有人基于你的输出做出决策,那么糟糕的数据将会导致糟糕的决策。

解决方案:使用assert语句来检查数据质量。pandas有相等测试,d6tstack有数据提取检查以及用于数据连接的d6tjoin

pandas相等测试:

https://pandas.pydata.org/pandas-docs/stable/reference/general_utility_functions.html

d6tstack:

https://github.com/d6t/d6tstack

d6tjoin:

https://github.com/d6t/d6tjoin/blob/master/examples-prejoin.ipyn

以下是数据检查的示例代码:

assert df['id'].unique().shape[0] == len(ids) # have data for all ids?
assert df.isna().sum()<0.9 # catch missing values
assert df.groupby(['g','date']).size().max() ==1 # no duplicate values/date?
assert d6tjoin.utils.PreJoin([df1,df2],['id','date']).is_all_matched() # all ids matched?


8. 不写代码说明文档


我明白,你急着做出一些分析结果。你把事情汇总到一起分析,将结果交给你的客户或老板。一个星期之后,他们回来说,“可以把XXX改一下吗”或者“可以更新一下这里吗”。你看着你的代码,但是并不记得你当初为什么这么写。现在就像是在运行别人的代码。

def some_complicated_function(data):    data = data[data['column']!='wrong']  data = data.groupby('date').apply(lambda x: complicated_stuff(x))    data = data[data['value']<0.9]    return data

解决方案:即使在你已经提交分析报告后,也要花费额外的时间,来对你做的事情编写说明文档。以后你会感谢自己,别人更会感谢你。那样显得你很专业!

9. 将数据保存为csv或pickle文件


回到数据,毕竟是在讲数据科学。就像函数和for循环一样,CSV和pickle文件很常用,但是并不好用。CSV文件不包含纲要(schema),因此每个人都必须再次解析数字和日期。Pickle文件解决了这个问题,但是它只能在python中使用,并且不能压缩。两者都不是存储大型数据集的最优格式。

def process_data(data, parameter):  data = do_stuff(data)  data.to_pickle('data.pkl')    data = pd.read_csv('data.csv')
process_data(data)
df_train = pd.read_pickle(df_train)

解决方案:使用parquet或其他带有数据纲要的二进制数据格式,在理想情况下可以压缩数据。d6tflow将任务的数据输出保存为parquet,无需额外处理。

parquet:

https://github.com/dask/fastparquet

d6tflow:

https://github.com/d6t/d6tflow-template

10. 使用jupyter notebook


最后一个是颇有争议的错误:jupyter notebook和csv文件一样普遍。许多人使用它们,但是这并不意味着它们很好。jupyter notebook助长了上述提到的许多不良编程习惯,尤其是:

  • 把所有文件保存在一个目录中

  • 编写从上至下运行的代码,而不是DAG

  • 没有对代码进行模块化

  • 很难调试

  • 代码和输出混在一个文件中

  • 没有很好的版本控制

  • 它容易上手,但是扩展性很差。

解决方案:使用pycharm和/或spyder。

pycharm:

https://www.jetbrains.com/pycharm/

spyder:

https://www.spyder-ide.org

作者简介:Norman Niemer是一家大规模资产管理公司的首席数据科学家,他在其中发布数据驱动的投资见解。他有哥伦比亚大学的金融工程专业理学硕士学位,和卡斯商学院(伦敦)的银行与金融专业理学学士学位。

原文标题:

Top 10 Coding Mistakes Made by Data Scientists

原文链接:

https://github.com/d6t/d6t-python/blob/master/blogs/top10-mistakes-coding.md

译者简介

李润嘉,首都师范大学应用统计硕士在读。对数据科学和机器学习兴趣浓厚,语言学习爱好者。立志做一个有趣的人,学想学的知识,去想去的地方,敢想敢做,不枉岁月。

翻译组招募信息

工作内容:需要一颗细致的心,将选取好的外文文章翻译成流畅的中文。如果你是数据科学/统计学/计算机类的留学生,或在海外从事相关工作,或对自己外语水平有信心的朋友欢迎加入翻译小组。

你能得到:定期的翻译培训提高志愿者的翻译水平,提高对于数据科学前沿的认知,海外的朋友可以和国内技术应用发展保持联系,THU数据派产学研的背景为志愿者带来好的发展机遇。

其他福利:来自于名企的数据科学工作者,北大清华以及海外等名校学生他们都将成为你在翻译小组的伙伴。

点击文末“阅读原文”加入数据派团队~

转载须知

如需转载,请在开篇显著位置注明作者和出处(转自:数据派ID:datapi),并在文章结尾放置数据派醒目二维码。有原创标识文章,请发送【文章名称-待授权公众号名称及ID】至联系邮箱,申请白名单授权并按要求编辑。

发布后请将链接反馈至联系邮箱(见下方)。未经许可的转载以及改编者,我们将依法追究其法律责任。

点击“阅读原文”拥抱组织

独家 | 10个数据科学家常犯的编程错误(附解决方案)相关推荐

  1. 推荐 :10个数据科学家常犯的编程错误(附解决方案)

    作者:Norman Niemer 翻译:李润嘉 校对:李洁 本文约2000字,建议阅读10分钟. 本文为资深数据科学家常见的10个错误提供解决方案. 数据科学家是"比软件工程师更擅长统计学, ...

  2. 新手数据科学家常犯的13种错误及其解决方法

    介绍 所以当你已经决定在数据科学这条道路走下去的时候.世界上越来越多的企业正在成为或者转型成为数据驱动的企业,世界变得越来越紧密,并且看起来每个企业都需要数据科学的人才.因此,对数据科学家的需求是巨大 ...

  3. csv科学计数法变为普通数字_数据科学家常遇到的10个错误

    作者 | 磐怼怼 来源 | 磐创AI 原文 | 数据科学家常遇到的10个错误 数据科学家是"在统计方面比任何软件工程师都要出色,在软件工程方面比任何统计学家都出色的人".许多数据科 ...

  4. 数据分析人员常犯的五大错误以及预防方法

    数据分析人员常犯的五大错误以及预防方法 你知道吗?每过去1分钟,Instagram上就多了1736111个赞,Snapchat上就多了284722个照片/视频分享,Tinder上就多了590278次& ...

  5. Github上的10个数据科学和机器学习知识库

    来源:DeepHub IMBA 本文共1200字,建议阅读5分钟在本文中将介绍一些对数据科学和机器学习爱好者最有用的 Github 代码库.(排名顺序不分先后) 1.The Algorithm 数据结 ...

  6. 独家 | 送你12个关于数据科学学习的关键提示(附链接)

    来源:Artinspiring/Dreamstime.com 翻译:国相洁 校对:丁楠雅 本文约3000字,建议阅读6分钟. 本文为你介绍了作为数据科学家需要掌握沟通能力和其它软技能方面知识. 小结: ...

  7. 独家 | 2种数据科学编程中的思维模式,了解一下(附代码)

    作者:Srini Kadamati 翻译:梁傅淇 校对:丁楠雅 本文约2500字,建议阅读10分钟. 本文以具体的例子阐释了如何最优化原型思维模式及生产流思维模式的应用. 数据科学的完整流程一般包含以 ...

  8. 年中盘点:2021年炙手可热的10家数据科学和机器学习初创公司

    当今企业正在利用不断增长的数据获得竞争优势,也就是采用数据科学.人工智能.机器学习.甚至是深度学习领域的新兴技术来准备和组织大数据,开发机器学习算法和预测模型,为分析师和IT员工所使用的业务智能应用提 ...

  9. 年中盘点:2020年炙手可热的10家数据科学和机器学习初创公司

    在企业能够利用大数据的优势之前,数据科学家和开发人员必须准备和组织好数据,并开发底层的机器学习算法和预测模型,以支持分析师和IT从业者使用的商业智能应用. 从传统上说,这是一个非常耗时的过程,但是有很 ...

最新文章

  1. 字符串最易犯的错误 总是和 那个\0 有关
  2. 【c语言】蓝桥杯算法提高 选最大数
  3. 微服务测试之性能测试
  4. Dataset之HiggsBoson:Higgs Boson(Kaggle竞赛)数据集的简介、下载、案例应用之详细攻略
  5. 【PAT乙级】1039 到底买不买 (20 分)
  6. 如何在圆柱表面滚花纹_更多地了解圆柱形铣刀
  7. Python修饰符--函数修饰符 “@”
  8. 特斯拉中国向招商银行贷款50亿元 工厂本月开始生产
  9. python列表中删除子列表_从列表列表中删除列表元素
  10. 如何修改macOS文件的默认打开方式?
  11. 深入解析Windows操作系统之第一章:概念与工具
  12. 2022最全知识点——RF接口自动化框架项目实战
  13. 虚拟机服务器断网,Vmware虚拟机断网不能上网的解决方法教程[多图]
  14. 基于MATLAB语音识别系统GUI界面
  15. 尝试修改smali码破解App
  16. Centos7自动备份数据库
  17. 【学术相关】博士开始内卷了吗?
  18. EasyTV 手机电视
  19. 计算机系统概论(原书第2版)部分课后习题答案(第四章)
  20. 数据库系统实验二作业-SQL实验报告

热门文章

  1. node上传资源到又拍云
  2. Spring Cloud Feign的两种使用姿势
  3. 解决MYSQL大表问题-实战篇(二)
  4. Spark Mllib里的Mllib基本数据类型(图文详解)
  5. Spring Boot不允许加载iframe问题解决
  6. HDU 5115 Dire Wolf ——(区间DP)
  7. Extjs 打包 failed to find any files
  8. Vbox在Linux 5上安装Oracle 11gR2 RAC
  9. 如何针对CMS系统进行SEO优化_
  10. “#ifdef __cplusplus extern C { #endif”的定义(zz)