修复glossary导出csv时的bug

This commit is contained in:
xunbu
2025-08-29 13:52:02 +08:00
parent 94cfd702c5
commit 0119661b8a
2 changed files with 24 additions and 18 deletions

View File

@@ -1,3 +1,3 @@
# SPDX-FileCopyrightText: 2025 QinHan # SPDX-FileCopyrightText: 2025 QinHan
# SPDX-License-Identifier: MPL-2.0 # SPDX-License-Identifier: MPL-2.0
__version__="1.3.0" __version__="1.3.0b1"

View File

@@ -1,5 +1,8 @@
# SPDX-FileCopyrightText: 2025 QinHan # SPDX-FileCopyrightText: 2025 QinHan
# SPDX-License-Identifier: MPL-2.0 # SPDX-License-Identifier: MPL-2.0
import csv
from io import StringIO
from docutranslate.ir.document import Document from docutranslate.ir.document import Document
@@ -24,9 +27,12 @@ class Glossary:
return prompt return prompt
else: else:
return "" return ""
@staticmethod @staticmethod
def glossary_dict2csv(glossary_dict: dict[str, str], seperator=",", stem="glossary_gen") -> Document: def glossary_dict2csv(glossary_dict: dict[str, str], delimiter=",", stem="glossary_gen") -> Document:
content = f"src{seperator}dst\n" csv_rows = [[src, dst] for src, dst in glossary_dict.items()]
for src, dst in glossary_dict.items(): content = StringIO()
content += f"{src}{seperator}{dst}\n" writer = csv.writer(content, delimiter=delimiter)
return Document.from_bytes(content=content.encode("utf-8"), suffix=".csv", stem=stem) writer.writerow(['src', 'dst'])
writer.writerows(csv_rows)
return Document.from_bytes(content=content.getvalue().encode("utf-8"), suffix=".csv", stem=stem)