diff --git a/CHANGELOG.md b/CHANGELOG.md index 2d10808..df750b5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ # WordZero 更新日志 +## [Unreleased] + +### 🐛 修复 +- `Table.GetCellText` 现在返回单元格内所有段落与所有 Run 的完整文本,并以 `\n` 连接段落,修复此前只能获取第一段首个 Run 文本导致多行内容丢失的问题。 + - 影响:如果下游代码假设无换行符,需自行 `strings.ReplaceAll(text, "\n", "")` 或按需拆分。 + - 限制:同一段落内的 `` 软换行尚未单独解析(未来可扩展)。 + + ## [v1.3.6] - 2025-06-04 ### 🚀 新增功能 diff --git a/pkg/document/README.md b/pkg/document/README.md index 79cae2c..1806720 100644 --- a/pkg/document/README.md +++ b/pkg/document/README.md @@ -381,7 +381,10 @@ func demonstrateTemplateInheritance() { ### 单元格操作 - [`GetCell(row, col int)`](table.go#L502) - 获取指定单元格 - [`SetCellText(row, col int, text string)`](table.go#L515) - 设置单元格文本 -- [`GetCellText(row, col int)`](table.go#L548) - 获取单元格文本 +- [`GetCellText(row, col int)`](table.go#L623) - 获取单元格文本(已升级:返回单元格内所有段落与 Run 的完整内容,段落之间使用 `\n` 分隔) + - 旧行为:仅返回第一个段落的第一个 Run 文本,导致多行/软换行内容丢失 + - 新行为:遍历所有段落与其下所有 Run,拼接文本;空段落跳过内容但仍产生段落换行(除末尾) + - 注意:如果未来需要保留 Word 中 ``(同一段落内的手动软换行),需扩展解析逻辑;当前仅按段落分隔 - [`SetCellFormat(row, col int, format *CellFormat)`](table.go#L691) - 设置单元格格式 - [`GetCellFormat(row, col int)`](table.go#L1238) - 获取单元格格式 diff --git a/pkg/document/table.go b/pkg/document/table.go index 3d6bae5..37f053a 100644 --- a/pkg/document/table.go +++ b/pkg/document/table.go @@ -627,11 +627,21 @@ func (t *Table) GetCellText(row, col int) (string, error) { return "", err } - if len(cell.Paragraphs) == 0 || len(cell.Paragraphs[0].Runs) == 0 { - return "", nil - } + if len(cell.Paragraphs) == 0 { + return "", nil + } - return cell.Paragraphs[0].Runs[0].Text.Content, nil + var result string + for idx, para := range cell.Paragraphs { + for _, run := range para.Runs { + result += run.Text.Content + } + // 段落之间添加软换行符(除最后一个段落) + if idx < len(cell.Paragraphs)-1 { + result += "\n" + } + } + return result, nil } // GetRowCount 获取表格行数