利用WPS 中的PY脚本功能,使用 Python 统计 WPS 在线表格数据(案例是统计开发计划任务进度)

使用 Python 统计 WPS 表格开发进度教程

输出结果

运行代码后,将输出整体进度和按负责人分组的进度统计。整体进度包括任务数量进度和工时权重进度,按负责人分组的进度包括任务完成率和工时完成率。

导入 WPS 表格数据

使用 pandas 的 read_excel 方法读取 WPS 表格数据。假设表格包含列:任务、优先级、工时(天)、负责人、进度。

python 复制代码
import pandas as pd
df = pd.read_excel('xxx系统.xlsx', sheet_name="xxx系统(feature-plan-2.0.1)")

如果是在线表格,那么使用wps提供的api,

https://airsheet.wps.cn/pydocs/db_table/dbt.html 数据表(智能表格)

https://airsheet.wps.cn/pydocs/work_table/xl.html 工作表

筛选关键任务

筛选优先级为"非常重要"且工时不为空的任务。

python 复制代码
task_df = df[(df['优先级'] == '非常重要') & (df['工时(天)'].notna())].copy()
计算整体进度

统计任务数量进度和工时权重进度。

python 复制代码
total_tasks = len(task_df)
completed_tasks = len(task_df[task_df['进度'] == 1])
progress_by_count = completed_tasks / total_tasks

total_hours = task_df['工时(天)'].sum()
completed_hours = (task_df['工时(天)'] * task_df['进度']).sum()
progress_by_hours = completed_hours / total_hours

result = {
    '总任务数': total_tasks,
    '已完成任务数': completed_tasks,
    '任务数量进度': f"{progress_by_count:.1%}",
    '总工时(天)': total_hours,
    '已完成工时(天)': completed_hours,
    '工时权重进度': f"{progress_by_hours:.1%}"
}
result_df = pd.DataFrame.from_dict(result, orient='index', columns=['值'])
print(result_df)
按负责人分组统计

计算每个负责人的任务总数、已完成任务数、任务完成率、总工时、已完成工时和工时完成率。

python 复制代码
progress_by_person = task_df.groupby('负责人').agg(
    任务总数=('任务', 'count'),
    已完成任务数=('进度', lambda x: (x == 1).sum()),
    总工时=('工时(天)', 'sum'),
    已完成工时=('工时(天)', lambda x: (x * task_df.loc[x.index, '进度']).sum())
).reset_index()

progress_by_person['任务完成率'] = progress_by_person['已完成任务数'] / progress_by_person['任务总数']
progress_by_person['工时完成率'] = progress_by_person['已完成工时'] / progress_by_person['总工时']

progress_by_person['任务完成率'] = progress_by_person['任务完成率'].apply(lambda x: f"{x:.1%}")
progress_by_person['工时完成率'] = progress_by_person['工时完成率'].apply(lambda x: f"{x:.1%}")

progress_by_person = progress_by_person.sort_values('总工时', ascending=False)
progress_by_person[['负责人', '任务总数', '已完成任务数', '任务完成率', '总工时', '已完成工时', '工时完成率']]
注意事项

确保 WPS 表格中的数据类型正确,例如工时列应为数值类型,进度列应为 0 到 1 之间的数值。如果数据格式不正确,可能导致计算结果错误。

相关推荐
max5006005 小时前
本地部署开源数据生成器项目实战指南
开发语言·人工智能·python·深度学习·算法·开源
q567315235 小时前
手把手教你用Go打造带可视化的网络爬虫
开发语言·爬虫·信息可视化·golang
Bling_Bling_15 小时前
面试常考:js中 Map和 Object 的区别
开发语言·前端·javascript
MonkeyKing_sunyuhua5 小时前
mac怎么安装uv工具
python·macos·uv
Source.Liu5 小时前
【Python基础】 19 Rust 与 Python if 语句对比笔记
笔记·python·rust
程序喵大人6 小时前
写C++十年,我现在怎么设计类和模块?(附真实项目结构)
开发语言·c++·类和模板
工业互联网专业6 小时前
基于Spark的新冠肺炎疫情实时监控系统_django+spider
python·spark·django·vue·毕业设计·源码·课程设计
Yh8702036 小时前
2025年经济学专业女生必考证书指南:打造差异化竞争力
python
黄焖鸡能干四碗6 小时前
信息系统安全保护措施文件方案
大数据·开发语言·人工智能·web安全·制造
BYSJMG6 小时前
大数据毕业设计推荐:基于Spark的零售时尚精品店销售数据分析系统【Hadoop+python+spark】
大数据·hadoop·python·spark·django·课程设计