继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

一个清单让你效率大增

慕神8447489
关注TA
已关注
手记 1259
粉丝 174
获赞 956

摘要:做数据开发要要具备什么基础?如何提高开发效率?请对照下面这个清单~

这是久违的第三篇文章,这次我们讲点没什么“技术含量”但绝对有用的东西。

你是否常常遇到这种情况: 写写画画苦思冥想后终于茅塞顿开想到了一个无与伦比绝世无双的idea(大雾),兴奋激动地扒了数据打算写个DEMO或搞个工程跑个漂漂亮亮的结果出来(大雾),结果写代码时磕磕碰碰处处不顺,在IDE和Google来回切换,思路老被打断影响发挥,折腾半天还没碰到自己设计的模型和算法的边,心里烦躁又凉凉?你并不是一个人。

根据观察,往往阻止我们coding如飞的,不是模型和算法的多晦涩和复杂(毕竟都在心里捋了多少遍了),而是日期处理,集合运算等常见逻辑,还有就是模块化、模式设计等代码工程化和重构。

代码工程化算是小头,这个范畴太大太重,以后有机会再展开讨论。然而,常见逻辑可是大头,没什么技术含量却要反反复复地实现。若能减少些反复Goolges的时间和精力,进入心流状态(还是大雾),对我们造轮子的效率和质量的提高还是很有帮助的!

这里,我给大家总结和整理了搞数据开发常见逻辑的清单,供大家参考和对照,不在于全面但在于有针对性(面面俱到不就是复制文档目录么),能涵盖数据科学开发中80%以上的需求。

如果有看到自己不熟悉的,建议及时查查资料整理笔记哦。这个清单我会根据后续开发的积累进行调整,若有遗漏,欢迎补充。往后我也会按照清单和主题整理例程做成cheatsheet,作为系列推出来!

下面上干货!

一般来说,从事数据开发,我们需要熟悉:

  • Java,Python,SQL,Shell(没人喜欢但真的需要…)等语言

  • Pandas、Numpy、Scipy等数据处理常用的库和包

  • Hadoop家族、Storm、Flink、TensorFlow、Keras等你的算法依赖的计算框架

对于上面提及的语言和库,我们需要熟悉如何用它们实现以下逻辑:

  • 日期处理

    • UTC、GMT等各种日期格式的格式化和反格式化

    • 当前系统日期的获取,日期的加、减、取整、周期序列生成等

  • 类型转换

    • 各语言的数据类型间转换和序列化

    • Pandas、Storm等数据处理库和计算框架内的类型转换和与语言原生类型的转换

  • 字符串处理

    • UTF-8, GBK等常见编码的转换和解码

    • 大小写转换、截取、拼接、查找、替换、正则表达式

  • 集合运算

    • 遍历和元素增删改查

    • 并、交、差、补等基础集合运算

    • filter、mapper、reduce等集合FP构造

    • one-hot编解码、tokenize等集合映射构造

  • 线性代数运算

    • Numpy, Pandas等数据处理包的行列变换

    • Tensorflows, Keras等计算框架提供的算子

  • 反射

  • 多线程和线程安全

    • 各语言下的多线程实现

    • 常用类和包的线程安全问题

    • 各计算框架的线程模型、资源共享、死锁解决等

  • 数据接入

    • Kafka等数据流的接入和配置

    • MySQL、Redis、HBase等RDMB和NoSQL的接入和配置、连接池和并发、增删查改等

  • 文件操作

    • CSV、JSON、XML等格式的数据文件读取、解析、偏移设置和流水化

    • Pandas、Storm等数据处理库和计算框架的缓存、模型、结果的序列化和持久化

  • 参数传递和配置解析

    • 管道和流水线的参数传递

    • 各语言的原生或第三方库的配置解析方法,如Python的optparse等

    • 各计算框架的配置解析方法和全局/局部等作用域,如Tensorflow的FLAGS等



作者:KAMIWei
链接:https://www.jianshu.com/p/ecbf5468c423


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP