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 获取表格行数