[已解决]Python-docx在Pycharm中代码无法自动补全的问题

前言

前不久在做一个python数据自动化处理的项目, 要求从excel表格提取有用数据并整理到word表格中去。用docx库处理word时, 我突然发现他居然不支持代码补全 !!!


解决过程

我在网上找了一些方法, 但大都是修改Pycharm设置重新添加索引,相对来说较为繁琐。后来我自己分析了一下docx模块的源码,发现居然是变量类型不同的锅 !

一般来说, 由于我们导入Document对象都是这种方式:

from docx import Document
document = Document()

跳转源代码后,发现Document定义在 "docx.api" 这个模块中, 但它本身不是类, 自然也就没有定义其他方法:

很明显, Document类的方法必然是定义在了其他文件中。于是在docx的目录下,我找到了document.py:

真正定义了用法的类

我们会发现在这个文件中定义了一个Document类, 并且类中定义了所有我们要用的方法, 看来这就是我们要找的类了 !


解决方法

将我们要用的document变量重新声明类型, 同时使用docx.document.Document对象来指代我们导入的Document对象就行了:

import docx.document
from docx import Document

# 对document的类型进行声明
document: docx.document.Document = Document()
可以看到Pycharm能显示代码补全

搞定, 这下我们就成功启动代码自动补全功能了 !


有关docx模块创建的表格无法修改宽度的问题, 在这篇博客里有解决方法了:

[已解决]Python-docx修改表格宽度无效的问题-CSDN博客

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Runfreeone

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值