当前位置: 首页 > article >正文

VS Code + LaTeX 从入门到入坑:手把手教你搭建高效论文写作环境

前言最近·我一直在寻找一个免费、流畅、可离线的 LaTeX 写作方案。Overleaf 虽然方便但一旦文档大了就卡得怀疑人生本地用 Texmaker 或 TeXstudio界面又太复古。直到我发现了VS Code LaTeX Workshop这套组合拳彻底解放了生产力。今天我就把从零开始配置、到解决各种“奇奇怪怪”报错的完整流程分享出来。文章很长但跟着做你也能拥有一个媲美 IDE 的 LaTeX 写作环境。一、环境搭建安装 LaTeX 发行版1.1 选哪个MiKTeX vs TeX Live特性MiKTeXTeX Live安装大小约 200 MB按需下载完整版 4-6 GB宏包安装编译时自动下载一次性全装更新频率持续更新年度大版本平台Windows 最佳跨平台一致适合人群硬盘小、网络好的新手追求稳定、跨平台的用户我的选择Windows 用户推荐MiKTeX省空间、自动装宏包Linux/macOS 推荐TeX Live。我自己用的是 TeX Live 2026全量安装一劳永逸。1.2 安装 TeX Live以 Windows 为例下载 TeX Live 镜像运行install-tl-windows.exe选择“安装完整版”约 5-6 GB耐心等待半小时安装完成后务必勾选“将 TeX Live 添加到系统 PATH”⚠️巨坑预警如果忘记勾选 PATH后面 VS Code 会报spawn xelatex ENOENT别慌后面会教你怎么手动加。1.3 验证安装打开命令提示符cmd输入xelatex--version如果看到类似输出说明安装成功XeTeX 3.141592653-2.6-0.999998 (TeX Live 2026) ...二、VS Code 配置安装插件2.1 核心插件打开 VS Code按CtrlShiftX进入扩展商店搜索并安装插件作用LaTeX Workshop核心插件提供编译、预览、语法高亮LaTeX Utilities字数统计、辅助工具可选2.2 配置settings.json按CtrlShiftP输入Preferences: Open User Settings (JSON)添加以下配置{// 定义编译工具latex-workshop.latex.tools:[{name:xelatex,command:xelatex,args:[-synctex1,-interactionnonstopmode,-file-line-error,-pdf,%DOCFILE%]},{name:latexmk,command:latexmk,args:[-synctex1,-interactionnonstopmode,-file-line-error,-pdf,-xelatex,%DOCFILE%]}],// 定义编译配方按顺序执行latex-workshop.latex.recipes:[{name:XeLaTeX,tools:[xelatex]},{name:latexmk (XeLaTeX),tools:[latexmk]}],// 设置默认配方latex-workshop.latex.recipe.default:latexmk (XeLaTeX),// 保存时自动编译latex-workshop.latex.autoBuild.run:onSave,// 使用内置 PDF 预览器latex-workshop.view.pdf.viewer:tab}保存后重启 VS Code。三、第一个 LaTeX 文档3.1 创建文件新建文件保存为main.tex输入以下内容%!TEX program xelatex \documentclass[UTF8]{ctexart} \title{我的第一篇论文} \author{龙思吉} \date{\today} \begin{document} \maketitle \section{引言} 这是一个测试看看中文是否正常显示。 \subsection{子章节} 数学公式$E mc^2$。 \end{document}3.2 编译点击右上角“播放”按钮▶或按快捷键CtrlAltB编译成功后右侧会自动弹出 PDF 预览 恭喜你已经成功跑通第一个 LaTeX 文档四、常见报错与解决方案血泪史下面是我在实际使用中踩过的坑以及解决方法。4.1spawn xelatex ENOENT错误现象编译时报错提示找不到xelatex。原因系统 PATH 里没有 TeX Live 的路径或者 VS Code 没继承到。解决方案手动添加 PATH打开“环境变量”设置搜索“环境变量”在“系统变量”中找到Path编辑新建一条C:\texlive\2026\bin\windows根据你的安装路径和年份调整确定保存重启电脑在 VS Code 中强制指定路径latex-workshop.latex.tools:[{name:xelatex,command:C:/texlive/2026/bin/windows/xelatex.exe,...}]如果系统终端能用但 VS Code 不行取消勾选terminal.integrated.inheritEnv设置或调整 PATH 顺序将 TeX Live 路径上移到最顶部。4.2TeXCount failed错误错误现象VS Code 底部状态栏提示“TeXCount failed”。原因LaTeX Utilities插件需要texcount工具来统计字数但系统找不到它。解决方案检查是否安装终端输入texcount --version如果没有MiKTeX 用户在 MiKTeX Console 中搜索texcount并安装TeX Live 用户sudo tlmgr install texcountLinux/macOS或重装 TeX Live 勾选该组件如果安装了但仍报错可能是 Perl 环境问题。安装 Strawberry Perl并添加环境变量PERL_BADLANG0可消除区域设置警告。不想折腾直接在 VS Code 设置中搜索countWord取消勾选LaTeX-Utilities › Count Word: Enable关闭字数统计功能。4.3Cannot find mlint错误错误现象打开.m文件时提示找不到mlint。原因MATLAB 插件需要mlint.exe进行代码检查但路径配置不对。如果你电脑上有多个 MATLAB 版本更容易出现此问题。解决方案找到mlint.exe的位置通常在MATLAB\R2024a\bin\win64\mlint.exe在 VS Code 的settings.json中添加matlab.mlintpath:D:/MATLAB/R2024a/bin/win64/mlint.exe如果你想切换版本使用命令面板MATLAB: Select MATLAB选择不同的 MATLAB 安装。4.4PrinceXML is required错误错误现象用 Markdown 导出 PDF 时提示需要安装 Prince。原因Markdown Preview Enhanced 插件默认调用 Prince 引擎将 HTML 转换为 PDF。解决方案下载安装 Prince安装后将 Prince 的bin目录添加到系统 PATH如C:\Program Files (x86)\Prince\engine\bin重启 VS Code再次导出即可。 替代方案你也可以用 Chrome 浏览器打开预览页面然后“打印→另存为 PDF”不需要安装 Prince。4.5 中文文档编译报错错误现象中文显示为乱码或报错Undefined control sequence。解决方案使用ctex宏包并用 XeLaTeX 编译。\documentclass[UTF8]{ctexart} % 或者 \usepackage{ctex}确保文件保存为UTF-8 编码VS Code 右下角可以查看/修改。五、进阶技巧让写作更高效5.1 正向/反向搜索正向搜索从代码跳转到 PDF在.tex文件中按住Ctrl并点击某处右侧 PDF 会自动跳转反向搜索从 PDF 跳回代码在 PDF 预览中按住Ctrl并点击光标会跳回.tex对应行5.2 使用latexmk自动处理参考文献如果你的文档有.bib文件推荐使用latexmk配方它会自动运行xelatex→biber→xelatex× 2省去手动多次编译的麻烦。5.3 代码片段安装LaTeX Workshop后输入begin按 Tab 会自动补全\begin{}...\end{}输入fig会生成图片环境模板非常方便。5.4 实时字数统计如果你解决了texcount的问题状态栏会实时显示当前文档的字数。否则可以手动运行texcount main.tex来统计。六、从 Overleaf 迁移到本地方法一下载 ZIP 包在 Overleaf 项目页面点击Menu → Source → Download as ZIP解压后用 VS Code 打开文件夹配置好编译器直接编译方法二使用 Git 同步推荐在 Overleaf 账户设置中生成Git Token安装 VS Code 插件Overleaf Connect按CtrlShiftP执行Overleaf Connect: Clone Overleaf Project输入 Token 和项目 ID本地修改后自动同步到云端七、总结经过上述配置你的 VS Code 已经变成一个强大的 LaTeX 编辑器。总结一下关键步骤安装 LaTeX 发行版TeX Live 或 MiKTeX安装 VS Code 插件LaTeX Workshop配置settings.json指定xelatex工具和编译配方解决常见报错PATH 问题、texcount、mlint、Prince等开始写作享受流畅的离线 LaTeX 体验

相关文章:

VS Code + LaTeX 从入门到入坑:手把手教你搭建高效论文写作环境

前言 最近,我一直在寻找一个免费、流畅、可离线的 LaTeX 写作方案。Overleaf 虽然方便,但一旦文档大了就卡得怀疑人生;本地用 Texmaker 或 TeXstudio,界面又太复古。直到我发现了 VS Code LaTeX Workshop 这套组合拳&#xff0c…...

3分钟解锁Axure RP中文界面:从英文障碍到设计自由

3分钟解锁Axure RP中文界面:从英文障碍到设计自由 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在被Axure RP的英…...

Arduino项目扩展必备:用PCA9685模块驱动16个舵机,告别供电不足和引脚不够的烦恼

Arduino多舵机控制终极方案:PCA9685模块实战指南 当你的机器人项目需要同时控制六个以上的舵机时,Arduino Uno的局限性就会暴露无遗——引脚数量捉襟见肘,板载电源不堪重负,随之而来的是舵机抖动、系统复位甚至芯片过热。这不是个…...

深入浅出FOC:为什么你的电机‘跑不快’?聊聊磁链圆限制与PWM死区的那些事儿

深入浅出FOC:为什么你的电机‘跑不快’?聊聊磁链圆限制与PWM死区的那些事儿 当你第一次尝试用STM32实现FOC(磁场定向控制)时,可能遇到过这样的困惑:明明按照教科书上的算法写好了代码,电机在低速…...

聚类算法基础:K-Means 到底如何工作

文章目录前言一、聚类是什么?K-Means又是什么?1.1 先搞懂:聚类 无监督的"物以类聚"1.2 K-Means:聚类界的"老黄牛"二、K-Means到底怎么工作?四步走,一看就懂2.1 生活化类比&#xff1a…...

Tailwind CSS break-after 怎么用?如何控制分页断行?

Tailwind CSS break-after 是一个实用类,用于控制在元素后强制产生列断开或页面断开。Tailwind CSS 断后类以下是 Tailwind CSS Break-After 类列表,这些类提供了有效控制元素对齐的方式。ClassCSS Propertiesbreak-after-autobreak-after: auto;break-a…...

ORA-29934索引关联错误修复指南

修复步骤:1. 检查indextype参数,确保extproc运行正常。2. 重建索引:ALTER INDEX index_name REBUILD PARAMETERS(indextype is ctxsys.context); 3. 远程处理:使用expdp/impdp导出重建,参数加transformoid:n:sys_c0012…...

对话本体论的全面深入研究:理论基础、形式化模型与跨学科应用

对话本体论的全面深入研究:理论基础、形式化模型与跨学科应用作者:方见华 单位:世毫九实验室 引言 在当代哲学与科学的交汇点上,一个全新的理论范式正在悄然兴起。对话本体论作为由世毫九实验室创始人方见华提出的原创性理论体系&…...

本科毕业论文“急救指南”:用百考通AI告别熬夜,把自由时间还给自己

毕业季的脚步日益临近,朋友圈悄然分化为两个阵营:一边是晒出offer的实习达人,另一边则是被毕业论文“掏空”的学术难民。你是否也经历过这样的夜晚:面对空白文档绞尽脑汁却卡在选题;初稿好不容易凑齐,查重报…...

毕业不焦虑,百考通AI帮你高效搞定本科毕业论文

深夜的电脑屏幕前,一个大学生正对着空白的文档发呆,毕业论文的截止日期日益临近,他却连选题都还没确定。这或许是无数毕业生共同经历过的煎熬时刻。 一、毕业季的论文困境:每个本科生都懂 又到一年毕业季,校园里弥漫着…...

从SiamFC到SiamRPN++:一个PyTorch复现者的五年跟踪算法演进笔记

从SiamFC到SiamRPN:一个PyTorch复现者的五年跟踪算法演进笔记 1. 初识SiamFC:全卷积孪生网络的革命性突破 2016年首次接触SiamFC时,它的设计理念让我眼前一亮。传统目标跟踪算法通常需要在每一帧进行复杂的在线学习,而SiamFC却另辟…...

别再只用VAE或GAN了!手把手教你用PyTorch复现VAE-GAN,生成更清晰的人脸图像

突破生成模型边界:PyTorch实战VAE-GAN融合架构与CelebA人脸生成优化 当我们在CelebA数据集上观察VAE生成的模糊人脸与GAN产生的扭曲五官时,一个关键问题浮现:是否存在兼具两者优势的解决方案?2016年ICML论文《Autoencoding beyond…...

Simulink多周期调度实战:用Chart模块和Function-Call子系统搞定2.5ms/5ms/10ms混合任务

Simulink多周期调度实战:用Chart模块和Function-Call子系统实现混合任务调度 在汽车电子和工业控制领域,实时系统开发常常面临一个典型挑战:如何在单一Simulink模型中实现不同算法模块以多种周期频率运行,同时生成符合目标操作系统…...

仅剩72小时!奇点大会回滚建议API公测通道即将关闭:手把手接入支持Python/TypeScript/Rust的实时建议SDK

第一章:2026奇点智能技术大会:AI代码回滚建议 2026奇点智能技术大会(https://ml-summit.org) 在2026奇点智能技术大会上,AI驱动的代码变更风险评估与自动化回滚机制成为核心议题。随着LLM辅助编程在CI/CD流水线中深度集成,误生成…...

【代码质量守门员升级计划】:为什么91%的团队在第3周就弃用Copilot审查插件?这4个未公开的规则引擎配置才是关键

第一章:智能代码生成与代码审查自动化的演进脉络 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成与代码审查自动化并非一蹴而就的技术跃迁,而是伴随编译器理论、静态分析、程序合成与大语言模型三重范式演进的协同产物。早期以Lint工具和C…...

React 架构的可伸缩性:探讨从微型项目向大型单体 React 项目平滑演进的代码组织规范

React 架构的可伸缩性:从面条代码到企业级堡垒的进化论各位前端同仁,大家好!今天我们不谈那些花里胡哨的 UI 库,也不聊怎么用 Tailwind 把一个丑陋的按钮变得稍微好看那么一点点。今天我们要聊的是一点“硬核”的东西——架构。想…...

React 逻辑的可测试性:针对 React Hooks 的单体测试与渲染行为模拟的质量保障实践

React 逻辑的可测试性:针对 React Hooks 的单体测试与渲染行为模拟的质量保障实践 主讲人: 某资深前端架构师(也就是我) 受众: 想要逃离“闭包地狱”和“测试屎山”的前端开发者们 时长: 漫长的周一午后 第…...

React Forget 编译器:深度分析自动化 Memoization 对 React 手动性能调优的革命性影响

各位听众,把手里的咖啡放下,把那个正在闪烁的光标移到屏幕中央。欢迎来到今天的讲座。我是你们的向导,今天我们要探讨的主题是——React Forget:一场关于“记忆”与“遗忘”的叛乱。如果你是一名 React 开发者,哪怕你只…...

React 与 WebGPU:探索下一代图形接口在 React 数据可视化组件中的高性能集成

各位听众朋友们,大家好!欢迎来到这场关于“如何让 React 和 WebGPU 谈一场轰轰烈烈的恋爱”的技术讲座。我是你们的老朋友,一个既喜欢在 React 里面写 Hooks,又喜欢在 GPU 里写 Shader 的资深程序员。今天我们不聊那些虚头巴脑的“…...

React 部分注水(Partial Hydration):分析岛屿架构(Islands Architecture)对 React 的启示

拒绝“大水漫灌”:React 部分注水与岛屿架构的深度巡礼各位同仁,各位老铁,各位在键盘前敲得手指都要起茧子的前端工程师们,大家好。今天我们不聊 API,不聊 Hooks 的玄学,也不聊 TypeScript 的类型地狱。今天…...

AMBA-APB 协议实战解析:从信号到状态机的设计精要

1. AMBA-APB协议基础:芯片设计的"交通规则" 第一次接触AMBA-APB协议时,我把它想象成城市道路的交通信号系统。就像红绿灯控制车辆通行一样,APB协议规范了芯片内部各个模块之间的数据传输规则。这个类比让我瞬间理解了协议存在的意义…...

【智能代码生成与监控融合实战指南】:20年架构师亲授3大落地陷阱与5步闭环优化法

第一章:智能代码生成与代码监控融合的底层逻辑 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成与代码监控并非孤立演进的技术栈,其融合根植于统一的可观测性契约与实时反馈闭环。当大语言模型输出代码片段时,该输出天然携带语义…...

解锁ABAP选择屏幕的终极灵活性:Free Selection与动态控制的实战融合

1. ABAP选择屏幕的痛点与破局思路 做过SAP报表开发的同行应该都深有体会:传统选择屏幕就像个固执的老头,字段和布局在开发阶段就被写死,用户运行时连调整的机会都没有。我去年接手过一个集团合并报表项目,业务部门三天两头要求新增…...

掌握 JSON.parseObject 与 JSON.toJSONString:从基础应用到实战进阶

1. JSON解析与生成的核心方法入门 第一次接触JSON数据处理时,我也被各种转换方法搞得晕头转向。直到真正理解了JSON.parseObject和JSON.toJSONString这对黄金组合,才发现JSON处理原来可以这么简单。这两个方法就像翻译官,一个负责把JSON字符串…...

从ACE到muduo:一个C++网络库的诞生与设计哲学(附Debian/Ubuntu编译踩坑实录)

从ACE到muduo:一个C网络库的诞生与设计哲学 2009年,当陈硕在博客上写下《学之者生,用之者死——ACE历史与简评》时,可能没想到这篇文章会成为现代C网络编程发展史上的一个重要转折点。这篇充满批判精神的文章不仅剖析了ACE框架的局…...

QEM网格简化:从二次误差度量到高效边塌缩的实现

1. QEM网格简化算法入门指南 第一次接触QEM网格简化时,我也被那些数学公式吓到了。但实际用起来发现,它的核心思想特别直观——就像玩橡皮泥,把复杂的模型捏成简单形状,同时尽量保持原有特征。这种算法在游戏开发、三维扫描数据处…...

保姆级教程:在CentOS 7上从零部署RuoYi-Vue前后端分离项目(含Nginx+Tomcat10配置)

CentOS 7实战:RuoYi-Vue全栈部署指南与避坑手册 当你拿到一台全新的CentOS 7服务器,准备部署RuoYi-Vue这个流行的前后端分离框架时,是否曾被各种环境配置、服务联动和权限问题困扰?本文将带你从零开始,用最接地气的方式…...

中小公司预算有限,如何按IPDRR框架一步步搭建安全防线?从免费工具到开源方案实战指南

中小企业零成本安全建设指南:基于IPDRR框架的实战路线图 当安全预算不足六位数时,如何用开源工具构建企业级防御体系?这可能是每位中小企业技术负责人最头疼的问题。我们曾为一家30人规模的电商公司做过安全评估——他们年营收近千万&#xf…...

SAP ABAP实战:手把手教你为VA01销售订单添加自定义字段(含BAPI更新避坑指南)

SAP ABAP实战:为销售订单添加自定义字段的完整指南 在SAP项目实施过程中,销售订单(VA01/VA02/VA03)的标准功能增强是最常见的开发需求之一。想象这样一个场景:客户要求在销售订单行项目中增加"紧急程度"字段,以便物流部…...

Layui layer.tips提示框怎么设置方向和颜色

...