网易首页 > 网易号 > 正文 申请入驻

润乾SPL:这可能是交互性最强的数据分析工具

0
分享至

Excel 和 BI 是常用的数据分析工具,很适合完成初级的数据分析任务,比如统计各月销售总额,计算各组的平均订单金额和购买频次等。但随着业务需求升级,更复杂的任务用 Excel 或 BI 就很难完成了,比如要找出股票连续上涨 5 天以上的区间;求每 7 天中连续 3 天活跃的用户数;统计每个用户从“注册”到“首次购买”间隔 3 天、7 天、30 天等不同时间段内的用户数分布。这些任务通常涉及跨行数据、复杂分组、滑动窗口或条件判断,用 Excel 很难做,BI 更是没戏,这时就只能指望编程了。

然而,编程语言虽然有更强的运算能力,但交互性却远不如 Excel 和 BI。在 Excel 中每编写或修改一个公式,结果都能实时呈现,有新想法可以立即修改再观察。这样,分析师可以根据前一步的结果决定下一步的动作,逐步探索分析,但编程语言通常却缺少这样的结果反馈机制。如果都是简单语句,SQL 可以每次生成中间表来查询结果,但这种任务 Excel 做起来更方便,期望用编程实现的运算经常会较复杂,写出的 SQL 常常嵌套多层,子查询还不能独立运行,想看中间结果就非常费劲了;Python 在分步方面略好一点,但也要主动 print 输出,而且代码要整体运行才有结果。这些编程语言在交互方面的方便程度都远远不如 Excel,不能像 Excel 那样随时想看哪里看哪里。

交互性和强计算似乎不可兼得,享受交互性就要容忍弱计算能力,想要强计算能力就没法兼顾交互性。这是很多数据分析场景面临的两难。

SPL 解决之道

SPL 可以很好解决这个问题。SPL(Structured Process Language)是一门特别适合数据分析的编程语言,在具备强计算能力的同时也拥有堪比 Excel 等界面工具的交互性。

交互能力

SPL 采用网格式编程,代码写在格子里,这与大多数文本编程语言有很大不同。
这是 SPL 的 IDE 整体外观和特点:

网格代码带来一大好处在于,可以像 Excel 一样用单元格承载计算结果。多个步骤落在不同格子里,每个格子的计算结果实时查看,像 Excel 一样想看哪里看哪里。后面的格子也可以像 Excel 一样通过单元格名(如 A1、B2)来引用前面格子的计算结果,非常方便且直观。

我们来解释这段代码,细致地感受一下 SPL 的交互性。
在 A1 中使用 T 函数读入股票交易记录:

接下来在 A2 格按照股票代码 CODE 和交易日期 DT 排序,同样点击执行后在右侧可以看到排序后的结果。

然后按照条件分组,将 CODE 相同且收盘价 CL 大于上一日的数据分到一组,group 的 @i 选项表示满足条件将产生新的分组。代码中的 CODE[-1] 和 CL[-1[ 表示对上一行的引用,这是 SPL 特有的语法,可以很方便地实现有序计算。而且,SPL 的分组可以保持分组子集,即分组的结果是由分组子集构成的集合,这也是许多程序语言不具备的能力。

前面执行过的代码已经有了结果,不必再重复执行,否则步骤较多或者数据量较大时执行慢会浪费时间。这时可以使用“计算当前格”功能。点击工具栏上的计算器图标就可以只计算当前格,在右侧即可看到计算结果。
相比之下,SQL 连分步的能力都没有,自然享受不到这样的便利;而 Python 也要整体执行,不能单独执行某一步,交互便利性远不如 SPL。

接下来用 select 函数筛选符合条件(连续上涨 5 天)的区间:

最后把所有符合的结果整合到一起:

Excel 计算出连续上涨的天数并不难,但也没有保持分组子集的方法,更不能进一步筛选出相应区间,所以难以完成这个任务。这时只能人工肉眼筛选了,数据较多时显然不太现实。SPL 拥有比 Excel 更方便的计算能力,在这个任务中也可见一斑。

这时如果发现目标结果较多,想要改变筛选条件,比如查看连涨 10 天的区间。只要将 A4 中的筛选条件大于 5 改成 10,再使用“计算单元格”功能就可以了:

如果还不满意,则可以继续调整,“观察 - 调整 - 反馈”逐步完成分析任务。
从这个过程可以看出,SPL 作为一种程序语言,却具备了与 Excel 相当的交互能力。探索分析过程中写的代码都留在格子,必要时还可以重复执行(比如更换了源数据)。

程序能力

作为编程语言,SPL 提供所有程序语言都具备的循环、分支流程,提供丰富的计算类库和数据对象。上面计算连涨区间的示例过程中就运用了 SPL 的有序和集合相关运算,在强计算能力的支持下,可以很轻松完成各类复杂的数据分析任务。

相比之下,SQL 和 Python 这方面要更弱,这个连涨区间的任务用 SQL 就很难写出来,Python 也不容易。为了写出代码对比,我们把问题简化成计算每只股票最长连续上涨天数。

SQL:

SELECT CODE, MAX(con_rise) AS longest_up_days
FROM (
SELECT CODE, COUNT(*) AS con_rise
FROM (
SELECT CODE, DT,
SUM(updown_flag) OVER (PARTITION BY CODE ORDER BY CODE, DT) AS no_up_days
FROM (
SELECT CODE, DT,
CASE WHEN CL > LAG(CL) OVER (PARTITION BY CODE ORDER BY CODE, DT) THEN 0
ELSE 1 END AS updown_flag
FROM stock
)
)
GROUP BY CODE, no_up_days
)
GROUP BY CODE

嵌套多层,看懂都不容易,专业程序员都未必写得出。

Python:

import pandas as pd
stock_file = "StockRecords.txt"
stock_info = pd.read_csv(stock_file,sep="\t")
stock_info.sort_values(by=['CODE','DT'],inplace=True)
stock_group = stock_info.groupby(by='CODE')
stock_info['label'] = stock_info.groupby('CODE')['CL'].diff().fillna(0).le(0).astype(int).cumsum()
max_increase_days = {}
for code, group in stock_info.groupby('CODE'):
max_increase_days[code] = group.groupby('label').size().max() – 1
max_rise_df = pd.DataFrame(list(max_increase_days.items()), columns=['CODE', 'max_increase_days'])

比 SQL 要容易些,但还是要硬写循环,仍不简单。

有了强大有序和集合运算的 SPL 只要三行搞定:

1、StockRecords.xlsx
2、=T(A1).sort(DT)
3、=A2.group(CODE;~.group@i(CL

从这个例子上看,SQL 和 Python 针对很多分析任务时表现出来计算方便度还不如 Excel。

总结一下,SPL 就像是插上了编程语言翅膀的 Excel,完美结合了 Excel 和编程语言在数据分析方面的优点,交互性与编程能力强强联合,助力数据分析师。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
官媒发文!宗馥莉再破天花板!让亲叔宗泽后和整个商界沉默了

官媒发文!宗馥莉再破天花板!让亲叔宗泽后和整个商界沉默了

山野卢员外
2026-01-10 22:45:57
华人成为新西兰女首富!史上第一次,生于中国,12岁来奥克兰

华人成为新西兰女首富!史上第一次,生于中国,12岁来奥克兰

小熊侃史
2025-12-20 10:50:58
港媒突然曝料澳门赌业大亨“洗米华”与千亿电诈头目存在巨额交易!陈志1000多亿资产被封,美国“偷走”九成

港媒突然曝料澳门赌业大亨“洗米华”与千亿电诈头目存在巨额交易!陈志1000多亿资产被封,美国“偷走”九成

澳门月刊
2026-01-09 09:18:41
哈梅内伊开始大范围断网,革命卫队将与中俄军演,伊朗进入关键期

哈梅内伊开始大范围断网,革命卫队将与中俄军演,伊朗进入关键期

温读史
2026-01-10 07:33:53
大家快看看中间这个穿红衣服的美女是谁呀?她真的好有气质

大家快看看中间这个穿红衣服的美女是谁呀?她真的好有气质

阿废冷眼观察所
2026-01-04 13:31:53
青岛山姆会员商店今年5月开业

青岛山姆会员商店今年5月开业

先锋新闻
2026-01-10 13:16:25
马斯克预言再成真,特斯拉FSD重大突破

马斯克预言再成真,特斯拉FSD重大突破

电动知家
2026-01-10 11:11:56
慈禧太后一天的生活开销,放在今天,大概需要多少人民币维持?

慈禧太后一天的生活开销,放在今天,大概需要多少人民币维持?

铭记历史呀
2026-01-08 08:42:11
国行 Apple Watch 马上迎来新功能,为国内 2000 万患者而来

国行 Apple Watch 马上迎来新功能,为国内 2000 万患者而来

爱范儿
2026-01-09 18:41:45
安妮海瑟薇推特自拍被玩坏!喊话Grok脱衣、变猫女

安妮海瑟薇推特自拍被玩坏!喊话Grok脱衣、变猫女

游民星空
2026-01-08 22:03:29
鸡腿公主给科技大佬当外室

鸡腿公主给科技大佬当外室

毒舌扒姨太
2026-01-10 22:27:26
柬政府确认:太子集团创始人陈志等3人已被遣返回中国,此前柬国王颁令撤销陈志柬埔寨国籍

柬政府确认:太子集团创始人陈志等3人已被遣返回中国,此前柬国王颁令撤销陈志柬埔寨国籍

南国今报
2026-01-10 20:49:27
足总杯117年最大冷门!卫冕冠军首战出局,被业余球队淘汰

足总杯117年最大冷门!卫冕冠军首战出局,被业余球队淘汰

奥拜尔
2026-01-10 22:14:05
小雷:如果索尔斯克亚真那么厉害,为何离开曼联找不到工作?

小雷:如果索尔斯克亚真那么厉害,为何离开曼联找不到工作?

懂球帝
2026-01-10 16:25:08
找到阵眼了?24岁他打出“典礼中场”效果,他也许是皇马成功关键

找到阵眼了?24岁他打出“典礼中场”效果,他也许是皇马成功关键

里芃芃体育
2026-01-10 08:07:22
“演员闫学晶”,被禁止关注

“演员闫学晶”,被禁止关注

第一财经资讯
2026-01-10 10:23:52
足总杯超级冷门!黑马成立仅5年,5000人冲场欢庆,鲁尼弟弟狂喜

足总杯超级冷门!黑马成立仅5年,5000人冲场欢庆,鲁尼弟弟狂喜

奥拜尔
2026-01-10 22:35:34
为拍视频滞留斑马线跳舞,上海警方通报:4人被处罚

为拍视频滞留斑马线跳舞,上海警方通报:4人被处罚

上观新闻
2026-01-10 16:24:10
官宣辟谣!鹿晗这波操作,关晓彤颜面何存?

官宣辟谣!鹿晗这波操作,关晓彤颜面何存?

搞笑娱乐笑话
2026-01-08 22:12:49
中方:沉痛哀悼丹羽宇一郎

中方:沉痛哀悼丹羽宇一郎

新京报政事儿
2026-01-09 15:31:25
2026-01-10 23:55:00
七星贝
七星贝
加强品牌建设,赋能企业高质量发展
61文章数 0关注度
往期回顾 全部

头条要闻

男子带父母去四川"纯玩" 不料消费7万连上厕所都收费

头条要闻

男子带父母去四川"纯玩" 不料消费7万连上厕所都收费

体育要闻

怒摔水瓶!杜兰特30+12 难阻火箭遭双杀

娱乐要闻

吴速玲曝儿子Joe是恋爱脑

财经要闻

这不算诈骗吗?水滴保诱导扣款惹众怒

科技要闻

传DeepSeek准备第二次震惊全世界

汽车要闻

宝马25年全球销量246.3万台 中国仍是第一大市场

态度原创

本地
家居
数码
公开课
军事航空

本地新闻

云游内蒙|“包”你再来?一座在硬核里酿出诗意的城

家居要闻

木色留白 演绎现代自由

数码要闻

华硕Strix Neo AM5主板搭载64MB ROM,可预装Wi - Fi驱动

公开课

李玫瑾:为什么性格比能力更重要?

军事要闻

海空英雄高翔逝世 曾驾驶歼-6打爆美军机

无障碍浏览 进入关怀版