python实现钉钉通讯录导出Excel表

Python工具开源专栏

Py0004 python实现钉钉通讯录导出Excel表

前言

需求来源于公司,需要将钉钉通讯录以Excel表的形式导出到本地,方便定期备份。导出的Excel需要处理钉钉用户兼任多部门的数据问题。功能大致如下几点。(文末有github链接)

  1. 读取钉钉通讯录的用户列表、部门列表。
  2. 支持导出钉钉通讯录到JSON或Excel文档。
  3. 通过requests网络请求获取钉钉通讯录,前提需配置钉钉开放后台微应用。

工具技术要点:面向对象、网络请求 ,使用了py库requestsopenpyxl

目录结构

源代码目录结构:

复制代码
Dingtalk-Book2Excel
 |--------- assets
	  |--------- json					# 存放json资源文件
	  |--------- xlsx					# 存放excel资源文件
 |--------- components
	  |--------- __init__.py			# 初始化模块包文件
	  |--------- DingtalkOpenAPI.py	# 调用钉钉通讯录的网络请求工具类
	  |--------- ExcelHandle.py		# 导出Excel的工具类
	  |--------- JsonHandle.py		# 导出Json的工具类
 |--------- logs
 |--------- utils
	  |--------- __init__.py			# 初始化模块包文件
  	  |--------- utils_const.py		# 常量表
	  |--------- utils_logging.py		# log日志工具类
 |--------- dingtalk_book2excel.py	# py主程序源文件
 |--------- readme.md			# 
 |--------- LICENSE			# 
 |--------- requirements.txt	# py项目的依赖项

执行文件的目录结构:

复制代码
 |--------- dingtalk_book2excel.exe	# 主程序入口

部分演示

导出的JSON格式

导出的Excel格式

完整代码已在GitHub上开源

源码已在GitHub上开源:Dingtalk-Book2Excel

参考来源:钉钉文档-通讯录管理

相关推荐
草莓熊Lotso19 分钟前
unordered_map/unordered_set 使用指南:差异、性能与场景选择
java·开发语言·c++·人工智能·经验分享·python·网络协议
二川bro5 小时前
量子计算入门:Python量子编程基础
python
夏天的味道٥6 小时前
@JsonIgnore对Date类型不生效
开发语言·python
tsumikistep6 小时前
【前后端】接口文档与导入
前端·后端·python·硬件架构
小白学大数据7 小时前
Python爬虫伪装策略:如何模拟浏览器正常访问JSP站点
java·开发语言·爬虫·python
头发还在的女程序员8 小时前
三天搞定招聘系统!附完整源码
开发语言·python
温轻舟8 小时前
Python自动办公工具06-设置Word文档中表格的格式
开发语言·python·word·自动化工具·温轻舟
花酒锄作田9 小时前
[python]FastAPI-Tracking ID 的设计
python·fastapi
AI-智能9 小时前
别啃文档了!3 分钟带小白跑完 Dify 全链路:从 0 到第一个 AI 工作流
人工智能·python·自然语言处理·llm·embedding·agent·rag
d***956210 小时前
爬虫自动化(DrissionPage)
爬虫·python·自动化