Skip to content

LatexFormatting 是一个用于格式化 LaTeX 和 Markdown 文件的实用工具。LatexFormatting is a utility used to format LaTeX and Markdown files.

Notifications You must be signed in to change notification settings

Abyss2019/formatting

 
 

Repository files navigation

LatexFormatting is a utility used to format LaTeX and Markdown files. For English version, please go to branch main_en.

项目简介

LatexFormatting 是一个用于格式化 LaTeX 和 Markdown 文件的实用工具。该工具提供了多种选项来规范化数学公式和文本格式,特别是对由 ChatGPT 生成的 LaTeX 公式进行处理。

简单的演示(新的视频还没做) 【数学科研向】将 ChatGPT 的回答复制到 Markdown 文件并正常编译数学公式

窗口界面

主要功能

  1. 在中日韩字符和英文或数字之间添加空格
    默认启用: ✅

  2. 将多行空行变成单行空行
    默认启用: ✅

  3. 行内公式:规范 $ ... $ 环境
    默认启用: ❌

  4. 行内公式:规范 \( ... \) 环境
    默认启用: ❌

  5. 行内公式:替换 \( ... \)$ ... $ 环境 【适合ChatGPT的回答】
    默认启用: ❌

  6. 行间公式:规范 equation 环境
    默认启用: ❌

  7. 行间公式:规范 $$ ... $$ 环境
    默认启用: ❌

  8. 行间公式:规范 \[ ... \] 环境
    默认启用: ❌

  9. 行间公式:替换 \[ ... \]$$ ... $$ 环境【适合ChatGPT的回答】
    默认启用: ❌

  10. 行间公式:替换 equation$$ ... $$ 环境
    默认启用: ❌

  11. 行间公式:替换 \[ ... \]equation 环境
    默认启用: ❌

  12. 行间公式:替换 $$ ... $$equation 环境
    默认启用: ❌

  13. 将内嵌在 equation 中的 aligned 环境变成单独的 align 环境
    默认启用: ❌

  14. 去掉 alignequation 环境中用于不显示tag的 *
    默认启用: ❌

  15. 规范 \item 格式
    默认启用: ❌

  16. 规范化各级标题
    默认启用: ✅

  17. 将 Markdown 的标题等变成 LaTeX 对应物
    默认启用: ❌

  18. 将 Markdown 的 ** 包围变成 \textbf 环境
    默认启用: ❌

  19. 将 Markdown 的 * 包围变成 \textit 环境
    默认启用: ❌

  20. 去掉所有Markdown特征
    默认启用: ❌

  21. 规范 align 环境
    默认启用: ❌

  22. 一些小的实用功能
    默认启用: ❌

  23. 替换 equationequation* 环境,如果没有 label
    默认启用: ❌

额外说明

  1. 可以保存当前复选框情况,下次开启自动复现。
  2. 可以批量处理文件夹内所有 .md.tex 文件。
  3. 可以选择自动复制或者手动复制修改后内容。

使用方法

方法 1:从终端中打开(MAC,或者 WINDOWS 系统皆可)

请确认安装了 pyperclip

pip install pyperclip

在根目录下运行 main.py 会自动打开使用界面。

python main.py

方法 2:打包成可执行文件 formatting.exe 即可使用。支持多开。(仅限 WINDOWS 系统)

具体打包方法请看下面开发说明。【警告】 该软件可能会被杀毒软件识别并清除,请加入白名单。详情原因参考 PyInstaller打包的exe被防毒软件报毒怎么办

⚠️ 注意事项

如果左侧输入框变化时,右侧输出框没有反应。说明出了bug,请关闭重启。

如果typora不能正常编译公式

请在 typora 偏好设置中,请在 Markdown 的设置看是否与下图相同

typora_markdown_setting

开发说明

环境要求

  • Python 3.x
  • 必要的 Python 库:
    • tkintertk 是 python 标准库)
    • pyperclip
    • pyinstaller (如需另外生成exe文件的话)
    • 持续开发中,缺什么补什么吧

项目结构

project/
│
├── main.py                      # 主程序文件
├── icon.ico                     # 程序图标
├── text_processing.py           # 文本处理模块
├── file_operations.py           # 文件操作模块
└── README.md                    # 开发说明(本文件)

代码结构说明

main.py:主程序文件,包含 GUI 界面及主要逻辑。

text_processing.pyfile_operations.py 文件包含具体的文本处理和文件操作函数,请根据项目需要进行定义。

如何添加自定义的新功能

详见根目录下另一个 how_add_new_features.md 文件。

构建可执行文件 formatting.exe (仅限 WINDOWS 系统)

main.py 所在的目录下运行如下,使用 PyInstaller 创建一个可执行exe文件:

pyinstaller --onefile --noconsole --name formatting --icon=icon.ico --distpath ./ main.py

或者直接在双击 get_exe.bat

贡献指南

  1. Fork 此项目。
  2. 创建你的功能分支 (git checkout -b feature/AmazingFeature)。
  3. 提交你的更改 (git commit -m 'Add some AmazingFeature')。
  4. 推送到分支 (git push origin feature/AmazingFeature)。
  5. 创建一个新的 Pull Request。

联系方式

如有任何问题或建议,请联系作者:

About

LatexFormatting 是一个用于格式化 LaTeX 和 Markdown 文件的实用工具。LatexFormatting is a utility used to format LaTeX and Markdown files.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.9%
  • Batchfile 0.1%