/zjuthesis

Zhejiang University Graduation Thesis LaTeX Template

Primary LanguageTeXMIT LicenseMIT

浙江大学学位论文 LaTeX 模板

ZJUTHESIS GitHub release GitHub All Releases Commit Since Latest Release GithubAction GitHub Discussion

简介

本项目为浙江大学学位论文的 LaTeX 模板,包含本科生、硕士生与博士生模板,以及英文硕博士模板。

This is a LaTeX template for Zhejiang University graduation thesis/design. It provides undergraduate and graduate (master and doctor) templates. It also provides an English template for graduate students. See English template user manual for more details.

CC98 校内讨论贴

GitHub 讨论版

使用

zjuthesis 模板有三种使用方式,Overleaf,本地编译,或者 Container 编译:

  • Overleaf 是一个线上 LaTeX 编辑器,可以在不安装任何工具的情况下编写 LaTeX 文档,同时也可以和其他人共享文档,共同编辑。
  • 本地编译比 Overleaf 更快,而且本地编译可以使用 Git 来记录版本。推荐有能力的同学设置本地编译环境,并推荐使用 Visual Studio Code 配合 LaTeX workshop 插件 (vscode 使用方式见FAQ)。
  • Container 编译是使用 GitHub 提供的 Codespace 搭配 Container 来编译,这个环境提供了浏览器内的 VS Code 界面以及 TeX Live 的编译环境。这种方式适合熟悉 Container 与 GitHub Codespace 相关用法的同学使用。

Overleaf

  1. 下载模板代码 中的 zjuthesis-v*.*.*-overleaf.zip 文件
  2. 在 Overleaf 中上传这个 .zip 压缩文件以创建一个新 Overleaf 项目
  3. 在 Overleaf 界面左上角点击 "Menu"
    • 选择 "Compiler" 为 "XeLaTeX"
    • 选择 "TeX Live version" 为 "2019" 或者更新的版本
  4. 参照 Overleaf 项目中 fonts/README.md 的说明下载所需字体,并上传到 fonts 文件夹中
  5. 使用 Overleaf 编译
    • 选择专业模板与毕业学位的方式参见下文 "本地编译"

本地编译

  1. 安装 TeXLive 工具包,编译需要 XeTeX 引擎

  2. 下载模板代码, 每个专业模板都有预览 pdf 文件,可以单独下载查看。 模板代码请下载 zjuthesis-v*.*.*.zip 文件 (如果你在用 Clone 或者 Fork 得到的代码,请切换到最新的 release tag,避免 master 分支上的不稳定更新破环你的论文的样式)

  3. zjuthesis.tex\documentclass[]{zjuthesis} 部分填写个人信息,其中以下信息用于控制文档的生成:

    • Degreeundergraduate 时,编译本科生论文:
    Field Option 1 Option 2 Option 3
    Type thesis: 论文类 design: 设计类
    Period proposal: 开题报告 final: 最终论文/设计(含开题报告) paper: 最终论文/报告(无开题报告)
    BlindReview true: 生成盲审用 pdf(隐藏个人信息) false: 生成提交用 pdf
    MajorFormat general: 默认模板 config/format/major/ 下目录名相同
    • Degreegraduate 时,编译硕士生/博士生论文:
    Field Option 1 Option 2
    Type thesis: 学术论文 design: 专业学术论文
    BlindReview true: 生成盲审用 pdf(隐藏个人信息) false: 生成提交用 pdf
    MajorFormat general: 默认模板 config/format/major/ 下目录名相同
    GradLevel master: 硕士 doctor: 博士
    • 其他设置
    Field Option 1 Option 2
    PrintFilePath true: 在每页侧边打印该页对应 TeX 文件路径 false: 不打印此输出
    TwoSide true: 章节末的偶数页留白,保证下章节的标题位于奇数页 false: 取消偶数页留白
  4. body 目录下编写内容

  5. pages 目录下填写必要的内容,如审核评语等

  6. figure 目录下保存图片,在 body/ref.bib 内插入文献条目

  7. 在根目录下运行命令 latexmk(或者 latexmk -xelatex -outdir=out zjuthesis)即可使用 XeTeX 编译 pdf 文件到 out 目录(该目录不会被记录版本)。请务必使用此 latexmk 命令进行编译(除非你已经了解 LaTeX 的工作机制),否则你可能遇到参考文献无法显示等问题

  8. 如需使用 LuaTeX 编译,可运行命令 latexmk -pdflua -outdir=out

注意

  • 每年的三月底四月初会有 TeXLive 的版本升级,届时本模板会根据 TeXLive 的更新做出一定的修改,请在提交最终论文前查看并应用本模板的更新。
  • 如果你使用 Mac OS 10.15 及以上版本,并且 TexLive 中的 ctex 包版本低于 2.5,会产生宋体字体判断问题,导致编译得到的 pdf 中字体出现误差。要解决这个问题,可以将 ctex 包升级到 2.5 以上,或者临时在 ctex 包的选项中加入 fontset=macnew,详见 issue 79
  • 本模板已经兼容 TeXLive 2021。TeXLive 2018 以及之前的版本复制伪粗体文字会产生乱码,建议使用本地 TeXLive 的同学使用最新版 TeXLive。
  • 计算机专业的部分页面与学校通用格式不同,如果你是计算机专业的同学,请使用计算机专业的模板。

使用容器编译

本模板提供了一套配置文件,用以支持在容器中安装TeX Live,项目使用的字体,以及VS Code上的LaTeX Workshop插件,配合GitHub Codespaces可以做到开箱即用。感谢 FUTURETECH6 同学贡献的代码

GitHub Codespace使用方法:

  1. 创建个人的项目(直接fork,或自行clone并修改remote)
  2. 在个人的项目主页点击"Code"
  3. 点击"Codespaces"
  4. 点击"New codespace"
  5. 等待容器构建(这一过程约要10分钟,因为要在标准Ubuntu的镜像中安装TeX Live)
  6. 构建完成后,可以选择在VS Code(需要GitHub Codespaces插件)中或在浏览器中打开,然后按照在本地的使用方式使用

注意

  • 这一功能的初衷是为了方便性能较弱的设备(例如低功耗笔记本电脑)也能利用免费的云运算资源较快地完成编译,因此不建议在本地性能较强的机器上使用(请改用"本地编译")。

字数统计

本模板提供了一个脚本用于统计正文字数,请在根目录下使用 latexmk 编译一遍模板,然后执行脚本 script/utils/word_count.sh。 此脚本调用了 texcount 工具,该工具是 TeX Live 的一部分,不需要额外安装。

Slides 模板

作者用于毕业答辩的一个 Slides 模板 (Microsoft PowerPoint 模板)

HGGshiwo 同学于 2021 年开发了基于 Beamer 的 Slides 模板,有兴趣的同学可以参考如下几个 repo

参考文档

常见问题与解决方案请参考FAQ,模板使用请参考使用手册,模板修改与二次开发请参考开发手册

本模板所使用的各专业规范文件请参考 zjuthesis-std

贡献

对本项目最好的贡献方式是在 GitHub Issue 里提交你发现的 BUG,或者贡献 Pull Request。 如果你不熟悉 GitHub 的运作方式,也可以通过邮件联系我,联系方式位于 zjuthesis.tex 顶部。

本项目提供了 LaTeX 模板,但并不负责教会用户使用各种 LaTeX 工具与环境。 与工具和环境有关的问题(例如 TeXStudio 如何处理参考文献)请先自行上网搜索解决方案。 在本项目的 GitHub Issue 里也已经有很多相关内容可供查阅。 当以上尝试均失败后,可到本项目的 GitHub Discussion 板块进行讨论。

本项目的 Issue 板块只处理使用命令行 latexmk 命令编译后产生的问题,不处理使用其他工具(如 TeXStudio)产生的问题。

开源许可

本项目代码基于 MIT 协议开源

学校标志与学校文件的版权归浙江大学所有