【解决方法】python写Excel单元格截断长文本

原因

只出现在已存在 sharedStrings.xml(共享字符串表) 的 .xlsx 文件;

用 openpyxl 加载→修改单元格→保存后,长文本(通常 > 200--500 字符)后半段丢失;

调试时 cell.value 是完整的,仅写入后截断;

触发条件:

openpyxl ≥3.0(默认优先用 lxml);

lxml ≤5.3.x(有 bug);

文件使用 sharedStrings(Excel 默认开启)。

底层原因:旧版 lxml 在序列化 XML 长文本节点时,缓冲区处理不当导致截断,而 openpyxl 在写入 sharedStrings 时依赖了这个逻辑。

解决方法:升级 lxml 到 5.4.0+

bash 复制代码
pip install --upgrade lxml
  • lxml 5.4.0 修复了长文本序列化 bug;
  • 无需改代码,openpyxl 自动使用新版 lxml。
相关推荐
你好潘先生3 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师3 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码3 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf3 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes16 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户83562907805118 小时前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent1 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6251 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python
SelectDB2 天前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码2 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python