a site to share moments and soughts~

Victor's blog


  • Home
  • Archive
  • Tags
  • about
  •   

© 2025 Victor

Theme Typography by Makito

Proudly published with Hexo

TeX Live+VSCode的本地LaTeX配置

Posted at 2024-11-30 操作 

前言

两个月前,我把MacTex(TeX Live的mac发行版)从mac中删除,因为mac的磁盘空间不足。然而,MikTex带来的问题超乎我的想象。原本以为MikTex仅仅是精简了包,空间上大大缩减,谁知在编译中文的时候,MikTex频频出问题。Claude多次提醒我可能是MikTex对于中文的支持不够好。事实证明(至少在我的mac上如此)MikTex只能保证在编译诸如test.tex、test02.tex和test03.tex的时候不会出问题(也可能是因为我太菜了没搞明白)。

毕竟第一次使用MacTex是2024.6,赶着要数模,也没什么空来捣鼓,只能匆匆忙忙,大部分时间都在overleaf上了,便也没精力来看这个本地部署的LaTeX\LaTeXLATE​X。当时不知何时发现安装了2023和2024两个版本的TeX Live😅,(话说回来,其实在实际中在线的overleaf使用中,2023版本的也曾几次被启用过,来应对2017年的cls模板兼容性问题)自己便索性删掉换成体积更小的MacTex了。

使用 TexLive 代替 MiKTeX,因为 TeX Live 在 macOS 上的中文支持更好。 ——Claude

1
2
3
4
5
6
7
%test.tex

%纯英文
\documentclass{article}
\begin{document}
Hello World
\end{document}
1
2
3
4
5
6
7
8
9
10
%test02.tex

%使用xeCJK的简单中文xelatex
\documentclass{article}
\usepackage{xeCJK}
\setCJKmainfont{Songti SC}
\begin{document}
你好,世界
Hello World
\end{document}
1
2
3
4
5
6
7
8
9
10
%test03.tex

%使用ctex的简单中文xelatex
\documentclass{article}
\usepackage[fontset=none]{ctex} % 禁用默认字体配置
\setCJKmainfont{Songti SC} % 手动设置中文字体
\begin{document}
你好,世界
Hello World
\end{document}

然而,一旦遇到如下文档example.tex的preamble的时候,MikTex便会大量报错且重复尝试多次编译且耗时。

点击显示代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
% example.tex

% !Mode:: "TeX:UTF-8"
% !TEX program = xelatex

%\documentclass{cumcmthesis}
\documentclass[withoutpreface, bwprint]{cumcmthesis} %去掉封面与编号页
\usepackage[framemethod=TikZ]{mdframed}
\usepackage{subcaption} % 子标题
\usepackage{algorithm}
\usepackage{algorithmic}
\usepackage{float}
\usepackage{url}
\usepackage{listings}
\usepackage{xcolor}
\usepackage{listings}
\usepackage[UTF8, CJKmath=true, AutoFakeBold = true]{xeCJK}
\setCJKmainfont{Songti SC} % 设置中文字体,可以根据系统替换其他中文字体
\lstset{
columns=fixed,
numbers=left, % 在左侧显示行号
frame=none, % 不显示背景边框
backgroundcolor=\color[RGB]{245, 245, 244}, % 设定背景颜色
keywordstyle=\color[RGB]{40, 40, 255}, % 设定关键字颜色
numberstyle=\footnotesize\color{darkgray}, % 设定行号格式
commentstyle=\it\color[RGB]{0, 96, 96}, % 设置代码注释的格式
stringstyle=\rmfamily\slshape\color[RGB]{128, 0, 0}, % 设置字符串格式
showstringspaces=false, % 不显示字符串中的空格
language=Matlab, % 设置语言
}


\title{机场出租车调度与司机决策问题}
\tihao{C}

\begin{document}
\maketitle
\begin{abstract}

这个example.tex的preamble是老师给的国赛数模模板,还有个cumcmthesis.cls在同级目录下。

点击显示代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
%cumcmthesis.cls

\NeedsTeXFormat{LaTeX2e}[1995/12/01]
\ProvidesClass{cumcmthesis}
[2017/09/16 v2.6 Standard LaTeX Template for CUMCM]
%% Inital Code
\newif\if@mcm@bwprint\@mcm@bwprintfalse
\newif\if@mcm@preface\@mcm@prefacetrue
% tokens definition
%%%% 承诺书
\newcommand\mcm@tokens@keywords{}
\newcommand*\mcm@tokens@tihao{}
\newcommand*\mcm@tokens@baominghao{}
\newcommand*\mcm@tokens@schoolname{}
\newcommand*\mcm@tokens@membera{}
\newcommand*\mcm@tokens@memberb{}
\newcommand*\mcm@tokens@memberc{}
\newcommand*\mcm@tokens@supervisor{}
\newcommand*\mcm@tokens@yearinput{}
\newcommand*\mcm@tokens@monthinput{}
\newcommand*\mcm@tokens@dayinput{}
%%%% 编号专用页
% 没有
%% Declaration of Options
\DeclareOption{colorprint}{\@mcm@bwprintfalse}
\DeclareOption{bwprint}{\@mcm@bwprinttrue}
\DeclareOption{withoutpreface}{\@mcm@prefacefalse}
\DeclareOption*{\PassOptionsToClass{\CurrentOption}{article}}
%% Executing of Options
\ExecuteOptions{colorprint}
\ProcessOptions\relax
%% Loading Class
\LoadClass[a4paper,12pt]{article}
%% Loading Package
\RequirePackage{ifxetex}
\RequireXeTeX
\ifxetex\else
\ClassError{mcmthesis}{You must use the `xelatex' driver\MessageBreak Please choose `xelatex'}{%
Just choose `xelatex', no `pdflatex' or `latex' and so on.}
\fi
% 支持中文的 ctex 宏包
\RequirePackage{ctex}
% 页面布局
\RequirePackage{geometry}
% 数学宏包
\RequirePackage{amsmath}
\RequirePackage{amsfonts}
\RequirePackage{amssymb}
\RequirePackage{bm}
%\RequirePackage{titletoc}
% 设置颜色
\RequirePackage{xcolor}
% 插入图片
\RequirePackage{graphicx}
\RequirePackage{float}
% 表格
\RequirePackage{array}
%% 长表格
\RequirePackage{longtable}
%% booktabs 提供了\toprule 等命令.
\RequirePackage{booktabs,tabularx}
%% multirow 支持在表格中跨行
\RequirePackage{multirow}
%% 调整间隔, 让表格更好看些
\RequirePackage{bigstrut}
%% 在跨行表格中输入定界符
\RequirePackage{bigdelim}
% 保护脆落命令
\RequirePackage{cprotect}
% 设置代码环境
\RequirePackage{listings}
\RequirePackage{xcolor}
% 插入链接
\RequirePackage{url}
% 绘图的包
%\RequirePackage{tikz}
%\usetikzlibrary{snakes}

% 字图与子标题
\RequirePackage{subcaption}
\RequirePackage[titles]{tocloft}
%\renewcommand{\cftdot}{$\cdot$}
%\renewcommand{\cftsecdotsep}{1.5}
\renewcommand{\cftsecdotsep}{4.5}
\setlength{\cftbeforesecskip}{7pt}
\setlength{\cftbeforesubsecskip}{3pt}
%\setlength{\cftbeforesubsecskip}{5pt}
\renewcommand{\cftsecfont}{\bfseries\zihao{-4}\heiti}
\renewcommand{\cftsecleader}{\cftdotfill{\cftsecdotsep}}
\renewcommand{\cftsecaftersnumb}{\hskip.4em}



\definecolor{dkgreen}{rgb}{0,0.6,0}
\definecolor{gray}{rgb}{0.5,0.5,0.5}
\definecolor{mauve}{rgb}{0.58,0,0.82}

\lstset{
frame=tb,
aboveskip=3mm,
belowskip=3mm,
showstringspaces=false,
columns=flexible,
framerule=1pt,
rulecolor=\color{gray!35},
backgroundcolor=\color{gray!5},
basicstyle={\small\ttfamily},
numbers=none,
numberstyle=\tiny\color{gray},
keywordstyle=\color{blue},
commentstyle=\color{dkgreen},
stringstyle=\color{mauve},
breaklines=true,
breakatwhitespace=true,
tabsize=3,
}
% 首行缩进
\RequirePackage{indentfirst}
% 设置浮动体的标题
\RequirePackage{caption}
% 定制列表环境
\RequirePackage{enumitem}
% 下划线
\RequirePackage{ulem}
% 尺寸计算
\RequirePackage{calc}

\RequirePackage[titletoc,title]{appendix}

%\RequirePackage[title,toc,titletoc]{appendix}

\RequirePackage{etoolbox}
\AtBeginEnvironment{thebibliography}{%
\phantomsection
\addcontentsline{toc}{section}{\refname}
}
% 超链接 hyperref 的设置
\RequirePackage{hyperref}
% 智能自动化交叉引用
\RequirePackage{cleveref}
%% Document Layout
% 页面布局
\geometry{top=25mm,bottom=35mm,left=25mm,right=25mm, footskip=7mm}
\renewcommand*{\baselinestretch}{1.38}
% 修改tabular 环境, 设置表格中的行间距为正文行间距.
\let\mcm@oldtabular\tabular
\let\mcm@endoldtabular\endtabular
\renewenvironment{tabular}%
{\bgroup%
\renewcommand{\arraystretch}{1.38}%
\mcm@oldtabular}%
{\mcm@endoldtabular\egroup}
% 每行缩进两个汉字
\setlength\parindent{2em}
% 设置字体
\setmainfont{Times New Roman}
%\setmonofont{Courier New}
\setsansfont{Arial}
\setCJKfamilyfont{kai}[AutoFakeBold]{Heiti TC}
\newcommand*{\kai}{\CJKfamily{kai}}
\setCJKfamilyfont{song}[AutoFakeBold]{Songti SC}
\newcommand*{\song}{\CJKfamily{song}}

\renewcommand\normalsize{%
\@setfontsize\normalsize{12.05}{14.45}%
\abovedisplayskip 12\p@ \@plus3\p@ \@minus7\p@
\abovedisplayshortskip \z@ \@plus3\p@
\belowdisplayshortskip 6.5\p@ \@plus3.5\p@ \@minus3\p@}
% 数学环境, 定理等设置
\newtheorem{definition}{\mcm@cap@definition}
\newtheorem{theorem}{\mcm@cap@theorem}
\newtheorem{lemma}{\mcm@cap@lemma}
\newtheorem{corollary}{\mcm@cap@corollary}
\newtheorem{assumption}{\mcm@cap@assumption}
\newtheorem{conjecture}{\mcm@cap@conjecture}
\newtheorem{axiom}{\mcm@cap@axiom}
\newtheorem{principle}{\mcm@cap@principle}
\newtheorem{problem}{\mcm@cap@problem}
\newtheorem{example}{\mcm@cap@example}
\newtheorem{proof}{\mcm@cap@proof}
\newtheorem{solution}{\mcm@cap@solution}

% 浮动环境设置
% 默认情况下, \LaTeX{} 要求每页的文字至少占据 20%,否则该页就只单独放置一个浮动环境,
% 而这通常不是我们想要的, 我们将这个要求降低到 5%.
\renewcommand*{\textfraction}{0.05}
% 有时如果多个浮动环境连续放在一起, \LaTeX{}
% 会将它们分在几个不同页,即使它们可在同一页放
% 得下. 我们可以通过修改 |\topfraction| 和 |\bottomfraction| 分别设置顶端和底端的浮
% 动环境的最大比例.
\renewcommand*{\topfraction}{0.9}
\renewcommand*{\bottomfraction}{0.8}
% 有时\LaTeX{}会把一个浮动环境单独放在一页,
% 我们要求这个环境至少要占据 85% 才能单独放在一页.
% 注意: |\floatpagefraction| 的数值必须小于 |\topfraction|.
\renewcommand*{\floatpagefraction}{0.85}
% 关于图片 graphicx
% 如果图片没有指定后缀, 依次按下列顺序搜索
\DeclareGraphicsExtensions{.pdf,.eps,.jpg,.png}
% 设置图表搜索路径, 可以给图表文件夹取如下名字
\graphicspath{{figures/}{figure/}{pictures/}%
{picture/}{pic/}{pics/}{image/}{images/}}
% 图表标题
\DeclareCaptionFont{song}{\songti}
\DeclareCaptionFont{minusfour}{\zihao{-4}}
\captionsetup[figure]{%
format=hang, % 标题从第二行开始都有缩进, 应该和 justification=raggedright 的效果一样.
labelsep=quad, % 分隔符是一个空格
font={song,minusfour,bf}, % 图的字体, 宋体小四
position=bottom % position=bottom, 不代表标题放在下面, 标题仍放在你放\caption的位置.
}
\captionsetup[table]{%
format=hang, % 标题从第二行开始都有缩进, 应该和 justification=raggedright 的效果一样.
labelsep=quad, % 分隔符是一个空格
font={song,minusfour,bf}, % 表的字体, 宋体小四
position=top % position=bottom, 不代表标题放在下面, 标题仍放在你放\caption的位置.
}
% 列表环境设置
\setlist{%
topsep=0.3em, % 列表顶端的垂直空白
partopsep=0pt, % 列表环境前面紧接着一个空白行时其顶端的额外垂直空白
itemsep=0ex plus 0.1ex, % 列表项之间的额外垂直空白
parsep=0pt, % 列表项内的段落之间的垂直空白
leftmargin=1.5em, % 环境的左边界和列表之间的水平距离
rightmargin=0em, % 环境的右边界和列表之间的水平距离
labelsep=0.5em, % 包含标签的盒子与列表项的第一行文本之间的间隔
labelwidth=2em % 包含标签的盒子的正常宽度;若实际宽度更宽,则使用实际宽度。
}

% 超链接
\hypersetup{%
% xetex,
% unicode=false, % hyperref 和 xetex 同时使用时不能开启 Unicode 选项.
pdfstartview=FitH,
CJKbookmarks=true,
bookmarksnumbered=true,
bookmarksopen=true,
colorlinks, %注释掉此项则交叉引用为彩色边框(将colorlinks和pdfborder同时注释掉)
pdfborder=001, %注释掉此项则交叉引用为彩色边框
allcolors=black,
breaklinks=true}%
% \if@mcm@bwprint
% \AtBeginDocument{\hypersetup{hidelinks}}
% \else\relax\fi
\pdfstringdefDisableCommands{%
\def\cftdotfill{ }%
}
\lstnewenvironment{tcode}
{
\lstset{basicstyle = \small\ttfamily,
language=TeX,
tabsize = 4,
frame = single,
escapechar = `,
breaklines = true,
breakatwhitespace = true,
frameround = tttt,
}
}
{}
%%% crefformat settings
\crefformat{figure}{#2图~#1#3}
\crefrangeformat{figure}{图~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{figure}{图~(#2#1#3)}{和~(#2#1#3)}{,(#2#1#3)}{和~(#2#1#3)}

\crefformat{table}{#2表#1#3}
\crefrangeformat{table}{表(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{table}{表~(#2#1#3)}{和~(#2#1#3)}{,(#2#1#3)}{和~(#2#1#3)}

\crefformat{equation}{#2~(#1#3)}
\crefrangeformat{equation}{~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{equation}{~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{definition}{#2\mcm@cap@definition~#1#3}
\crefrangeformat{definition}{\mcm@cap@definition~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{definition}{\mcm@cap@definition~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{theorem}{#2\mcm@cap@theorem~#1#3}
\crefrangeformat{theorem}{\mcm@cap@theorem~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{theorem}{\mcm@cap@theorem~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{lemma}{#2\mcm@cap@lemma~#1#3}
\crefrangeformat{lemma}{\mcm@cap@lemma~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{lemma}{\mcm@cap@lemma~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{corollary}{#2\mcm@cap@corollary~#1#3}
\crefrangeformat{corollary}{\mcm@cap@corollary~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{corollary}{\mcm@cap@corollary~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{assumption}{#2\mcm@cap@assumption~#1#3}
\crefrangeformat{assumption}{\mcm@cap@assumption~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{assumption}{\mcm@cap@assumption~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{conjecture}{#2\mcm@cap@conjecture~#1#3}
\crefrangeformat{conjecture}{\mcm@cap@conjecture~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{conjecture}{\mcm@cap@conjecture~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{axiom}{#2\mcm@cap@axiom~#1#3}
\crefrangeformat{axiom}{\mcm@cap@axiom~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{axiom}{\mcm@cap@axiom~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{principle}{#2\mcm@cap@principle~#1#3}
\crefrangeformat{principle}{\mcm@cap@principle~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{principle}{\mcm@cap@principle~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{problem}{#2\mcm@cap@problem~#1#3}
\crefrangeformat{problem}{\mcm@cap@problem~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{problem}{\mcm@cap@problem~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{example}{#2\mcm@cap@example~#1#3}
\crefrangeformat{example}{\mcm@cap@example~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{example}{\mcm@cap@example~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{proof}{#2\mcm@cap@proof~#1#3}
\crefrangeformat{proof}{\mcm@cap@proof~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{proof}{\mcm@cap@proof~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}

\crefformat{solution}{#2\mcm@cap@solution~#1#3}
\crefrangeformat{solution}{\mcm@cap@solution~(#3#1#4)\;\~{}\;(#5#2#6)}
\crefmultiformat{solution}{\mcm@cap@solution~(#2#1#3)}{ 和~(#2#1#3)}{,(#2#1#3)}{ 和~(#2#1#3)}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%% Document Markup

% 生成封面, 使用\maketitle
\renewcommand{\maketitle}{\par
\begingroup
\newpage
\global\@topnum\z@ % Prevents figures from going at top of page.
\@maketitle
\endgroup
\global\let\thanks\relax
\global\let\maketitle\relax
\global\let\@maketitle\relax
\global\let\@thanks\@empty
\global\let\@author\@empty
\global\let\@date\@empty
\global\let\@title\@empty
\global\let\title\relax
\global\let\author\relax
\global\let\date\relax
\global\let\and\relax
}
\def\@maketitle{%
\newpage
\if@mcm@preface
\null
% 承诺书
\vskip2ex
\thispagestyle{empty}
{\zihao{4}\noindent\mcm@commit@string@headname\\[-8pt]
\noindent\rule[5pt]{\textwidth-1.34em}{.5pt}\par}
\begin{center}%
{\zihao{-3}\bfseries\heiti \mcm@commit@string@titlea \par}%
{\vskip1ex\zihao{3}\bfseries\songti \mcm@commit@string@titleb \par}
\end{center}
{\zihao{-4} \mcm@commit@string@contents \par}
{\vskip1ex\zihao{-4}
\renewcommand{\ULthickness}{0.4pt}\setlength{\ULdepth}{2pt}
\hspace*{2em}\mcm@commit@string@problemnum\uline{\hspace{1em}\mcm@tokens@tihao\hfill}\makebox[0.66em]{}\par
\mcm@commit@string@signupnum\uline{\hspace{1em}\mcm@tokens@baominghao\hfill}\makebox[0.66em]{}\par
\mcm@commit@string@schoolname\uline{\hfill\mcm@tokens@schoolname\hfill}\makebox[0.66em]{}\par
\newlength{\mcm@lenB}
\settowidth{\mcm@lenB}{\mcm@commit@string@membername\hspace{1em}1.}
\setlength{\mcm@lenB}{\textwidth-\mcm@lenB}
% 不这样做右边难以对齐!
\mcm@commit@string@membername
\begin{minipage}[t]{\mcm@lenB}
1.\uline{\hspace{1em}\mcm@tokens@membera\hfill} \makebox[0.46em]{}\par
2.\uline{\hspace{1em}\mcm@tokens@memberb\hfill} \makebox[0.46em]{}\par
3.\uline{\hspace{1em}\mcm@tokens@memberc\hfill} \makebox[0.46em]{}\par
\end{minipage}\par\vskip1ex
\mcm@commit@string@supervisorname\uline{\hspace{1em}\mcm@tokens@supervisor\hfill}\makebox[0.66em]{}\par
\hspace{0.1cm} ({\kaishu 指导教师签名意味着对参赛队的行为和论文的真实性负责})
%{\kaishu\mcm@commit@string@inform\par}
\vskip2ex
\newlength{\mcm@lenA}
\settowidth{\mcm@lenA}{请仔细核对,提交后将不再允许做任何修改。如}% 虽然"日期"刚好在"错误"下面, 但注意"日期"还会缩进, 所以要省去"填写""两字
\hspace*{\mcm@lenA}\mcm@commit@string@date\hspace{0.5em}\uline{\hfill\hspace{1em}\mcm@tokens@yearinput\hspace{1em}\hfill}%
\mcm@commit@string@year\uline{\hfill\mcm@tokens@monthinput\hfill}\mcm@commit@string@month%
\uline{\hfill\mcm@tokens@dayinput\hfill}\mcm@commit@string@day\makebox[1em]{}\par}
\vskip1ex
{\kaishu\bfseries\mcm@commit@string@inform\par}
\vfill
\null
% 编号专用页
\else
\fi
\makeothertitle
}

%% 定义 编号专用页
\def\makeothertitle{%
\if@mcm@preface
\par
\newpage
\null
\thispagestyle{empty}
{\zihao{4}\noindent\begin{tabularx}{\textwidth}{cXcX@{}}
\mcm@numberpage@string@headname & & \mcm@numberpage@string@allcountrynum&\\[-5pt]
\mcm@numberpage@string@headnameb & &\mcm@numberpage@string@allcountrynumb&\\
\cline{2-2}\cline{4-4}
\end{tabularx}

\vspace*{1.2em}

\noindent\rule{\textwidth}{1pt}\par}
\begin{center}
{\zihao{4}\bfseries\heiti \mcm@numberpage@string@titlea\par}
{\vskip1ex\zihao{3}\songti \bfseries\mcm@numberpage@string@titleb\par}
\end{center}\par
{%
\zihao{4}
\vskip3em
\hspace*{2em}\mcm@numberpage@string@appraiselog
\par
\newlength{\mcm@lenC}
\setlength{\mcm@lenC}{\textwidth-8.72em}
\setlength{\mcm@lenC}{\mcm@lenC/6}
\newlength{\mcm@lenD}
\settoheight{\mcm@lenD}{\mcm@numberpage@string@reviewer}
\setlength{\mcm@lenD}{\mcm@lenD+2em}
\newlength{\mcm@lenF}
\settoheight{\mcm@lenF}{\mcm@numberpage@string@remarks}
\setlength{\mcm@lenF}{\mcm@lenF+2em}
\newcolumntype{P}{@{}p{\mcm@lenC}@{}}
\hspace*{1.5em}\begin{tabular}{|!{\hspace{4pt}}c!{\hspace{4pt}}|*{6}{P|}}
\hline
\rule{0pt}{\mcm@lenD}\raisebox{0.6em}[0pt][0pt]{\mcm@numberpage@string@reviewer} & & & & & & \\\cline{1-7}
\rule{0pt}{\mcm@lenF}\raisebox{0.6em}[0pt][0pt]{\mcm@numberpage@string@remarks} & & & & & & \\
\hline
\end{tabular}\par
\vskip5em
\hspace*{2em}\mcm@numberpage@string@countrynum}

\vfill
{\zihao{-4}\kaishu\bfseries\mcm@numberpage@string@inform\par}

\null
\newpage
\null
\setcounter{page}{1}
{\centering \zihao{3}\bfseries \@title\par}
\vskip1ex
\else
\setcounter{page}{1}
{\centering \zihao{3}\bfseries \@title\par}
\vskip1ex
\fi
}

% 中文标题名称设置
\renewcommand\contentsname{\mcm@cap@contentsname}
\renewcommand\listfigurename{\mcm@cap@listfigurename}
\renewcommand\listtablename{\mcm@cap@listtablename}
\renewcommand\refname{\mcm@cap@refname}
\renewcommand\indexname{\mcm@cap@indexname}
\renewcommand\figurename{\mcm@cap@figurename}
\renewcommand\tablename{\mcm@cap@tablename}
\renewcommand\appendixname{\mcm@cap@appendixname}
\renewcommand\abstractname{\mcm@cap@abstractname}

% 中文标题格式设置
% 目录深度
\setcounter{secnumdepth}{3}
% 节标题格式, 居中, 使用\chinese命令修改计数器
\def\@seccntformat#1{\csname the#1\endcsname\ }
\renewcommand\thesection{\chinese{section}、}
\renewcommand\thesubsection{\arabic{section}\thinspace.\thinspace\arabic{subsection}}
\renewcommand\thesubsubsection{\thesubsection\thinspace.\thinspace\arabic{subsubsection}}
\renewcommand\section{\@startsection{section}{1}{\z@}%
{-3.5ex \@plus -1ex \@minus -.2ex}%
{2.3ex \@plus.2ex}%
{\centering\normalfont\Large\bfseries}}
\renewcommand\subsection{\@startsection{subsection}{2}{\z@}%
{-3.25ex\@plus -1ex \@minus -.2ex}%
{1.5ex \@plus .2ex}%
{\normalfont\large\bfseries}}
\renewcommand\subsubsection{\@startsection{subsubsection}{3}{\z@}%
{-3.25ex\@plus -1ex \@minus -.2ex}%
{1.5ex \@plus .2ex}%
{\normalfont\normalsize\bfseries}}
\renewcommand\paragraph{\@startsection{paragraph}{4}{\z@}%
{3.25ex \@plus1ex \@minus.2ex}%
{-1em}%
{\normalfont\normalsize\bfseries}}
\renewcommand\subparagraph{\@startsection{subparagraph}{5}{\parindent}%
{3.25ex \@plus1ex \@minus .2ex}%
{-1em}%
{\normalfont\normalsize\bfseries}}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Define new environment and command
%% 摘要两个字设置为 4 号.
%% 定义摘要环境
\renewenvironment{abstract}{%
\if@twocolumn
\section*{\abstractname}%
\else
\begin{center}%
{\zihao{4}\bfseries \abstractname\vspace{-.5em}\vspace{\z@}}%
\end{center}%
\quotation
\fi}
{\if@twocolumn\else\endquotation\newpage\null\fi}
\renewenvironment{quotation}
{\list{}{\listparindent 2em%
\itemindent \listparindent
\rightmargin\z@
\leftmargin\z@
\parsep \z@ \@plus\p@}%
\item\relax}
{\endlist}

\newcommand\keywords[1]{%
\renewcommand{\mcm@tokens@keywords}{#1}
\par
\vskip1ex
{\noindent\zihao{-4}\heiti\mcm@cap@keywordsname:}~{\mcm@tokens@keywords}
}
% 定义附录

% \renewcommand{\setthesection}{\appendixname\Alph{section}}
% \renewcommand\appendix{\par
% \setcounter{section}{0}%
% \setcounter{subsection}{0}%
% \gdef\thesection{\appendixname\@Alph\c@section}}
% 重定义参考文献环境
\renewenvironment{thebibliography}[1]
{\section*{\refname}%
\@mkboth{\MakeUppercase\refname}{\MakeUppercase\refname}%
\list{\@biblabel{\@arabic\c@enumiv}}%
{\settowidth\labelwidth{\@biblabel{#1}}%
\leftmargin\labelwidth
\advance\leftmargin\labelsep
\@openbib@code
\usecounter{enumiv}%
\let\p@enumiv\@empty
\renewcommand\theenumiv{\@arabic\c@enumiv}}%
\sloppy
\clubpenalty4000
\@clubpenalty \clubpenalty
\widowpenalty4000%
\sfcode`\.\@m}
{\def\@noitemerr
{\@latex@warning{Empty `thebibliography' environment}}%
\endlist}

\newcommand*\tihao[1]{%
\renewcommand{\mcm@tokens@tihao}{#1}}
\newcommand*\baominghao[1]{%
\renewcommand{\mcm@tokens@baominghao}{#1}}
\newcommand*\schoolname[1]{%
\renewcommand{\mcm@tokens@schoolname}{#1}}
\newcommand*\membera[1]{%
\renewcommand{\mcm@tokens@membera}{#1}}
\newcommand*\memberb[1]{%
\renewcommand{\mcm@tokens@memberb}{#1}}
\newcommand*\memberc[1]{%
\renewcommand{\mcm@tokens@memberc}{#1}}
\newcommand*\supervisor[1]{%
\renewcommand{\mcm@tokens@supervisor}{#1}}
\newcommand*\yearinput[1]{%
\renewcommand{\mcm@tokens@yearinput}{#1}}
\newcommand*\monthinput[1]{%
\renewcommand{\mcm@tokens@monthinput}{#1}}
\newcommand*\dayinput[1]{%
\renewcommand{\mcm@tokens@dayinput}{#1}}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%% Initialization
%%%数学定理相关的常量
\newcommand*{\mcm@cap@definition}{定义}
\newcommand*{\mcm@cap@theorem}{定理}
\newcommand*{\mcm@cap@lemma}{引理}
\newcommand*{\mcm@cap@corollary}{推论}
\newcommand*{\mcm@cap@assumption}{假设}
\newcommand*{\mcm@cap@conjecture}{猜想}
\newcommand*{\mcm@cap@axiom}{公理}
\newcommand*{\mcm@cap@principle}{定律}
\newcommand*{\mcm@cap@problem}{问题}
\newcommand*{\mcm@cap@example}{例}
\newcommand*{\mcm@cap@proof}{证明}
\newcommand*{\mcm@cap@solution}{解}
%%% 中文标题名称
\newcommand*{\mcm@cap@contentsname}{目录}
\newcommand*{\mcm@cap@listfigurename}{插图清单}
\newcommand*{\mcm@cap@listtablename}{附表清单}
\newcommand*{\mcm@cap@refname}{参考文献}
\newcommand*{\mcm@cap@indexname}{索引}
\newcommand*{\mcm@cap@figurename}{图}
\newcommand*{\mcm@cap@tablename}{表}
\newcommand*{\mcm@cap@appendixname}{附录}
\newcommand*{\mcm@cap@abstractname}{摘要}
%%% 中文关键字
\newcommand*{\mcm@cap@keywordsname}{关键词}

%%% 承诺书中的常量
\newcommand*\mcm@commit@string@headname{赛区评阅编号(由赛区组委会填写):}
\newcommand*\mcm@commit@string@titlea{\the\year 高教社杯全国大学生数学建模竞赛}
\newcommand*\mcm@commit@string@titleb{承\hspace{1em}诺\hspace{1em}书}
\newcommand\mcm@commit@string@contents{\quotation
我们仔细阅读了《全国大学生数学建模竞赛章程》和《全国大学生数学建模竞赛参赛规则》(以下简称 “竞赛章程和参赛规则”,可从http://www.mcm.edu.cn下载)。

我们完全清楚,在竞赛开始后参赛队员不能以任何方式,包括电话、电子邮件、“贴吧”、QQ群、微信群等,与队外的任何人(包括指导教师)交流、讨论与赛题有关的问题;无论主动参与讨论还是被动接收讨论信息都是严重违反竞赛纪律的行为。

我们完全清楚,在竞赛中必须合法合规地使用文献资料和软件工具,不能有任何侵犯知识产权的行为。否则我们将失去评奖资格,并可能受到严肃处理。

{\bfseries\song 我们以中国大学生名誉和诚信郑重承诺,严格遵守竞赛章程和参赛规则,以保证竞赛的公正、公平性。如有违反竞赛章程和参赛规则的行为,我们将受到严肃处理。}

我们授权全国大学生数学建模竞赛组委会,可将我们的论文以任何形式进行公开展示(包括进行网上公示,在书籍、期刊和其他媒体进行正式或非正式发表等)。
\endquotation
}
\newcommand*\mcm@commit@string@problemnum{我们参赛选择的题号(从A/B/C/D/E中选择一项填写):}
\newcommand*\mcm@commit@string@signupnum{我们的报名参赛队号(12位数字全国统一编号):}
\newcommand*\mcm@commit@string@schoolname{参赛学校(完整的学校全称,不含院系名):}
\newcommand*\mcm@commit@string@membername{参赛队员 (打印并签名) :}
\newcommand*\mcm@commit@string@supervisorname{指导教师或指导教师组负责人 (打印并签名):}
\newcommand\mcm@commit@string@inform{\quotation
\noindent{(\bfseries\kai 请勿改动此页内容和格式。此承诺书打印签名后作为纸质论文的封面,注意电子版论文中不得出现此页。%
以上内容请仔细核对,如填写错误,论文可能被取消评奖资格。)}
\endquotation
}
\newcommand*\mcm@commit@string@date{日期:}
\newcommand*\mcm@commit@string@year{年}
\newcommand*\mcm@commit@string@month{月}
\newcommand*\mcm@commit@string@day{日}
\newcommand*\mcm@commit@string@appraisenum{赛区评阅编号(由赛区组委会评阅前进行编号):}

%%% 编号专用页中的常量
\newcommand*\mcm@numberpage@string@headname{赛区评阅编号:}
\newcommand*\mcm@numberpage@string@headnameb{(由赛区填写)}
\newcommand*\mcm@numberpage@string@allcountrynum{全国评阅编号:}
\newcommand*\mcm@numberpage@string@allcountrynumb{(全国组委会填写)}
\newcommand*\mcm@numberpage@string@titlea{\the\year 高教社杯全国大学生数学建模竞赛}
\newcommand*\mcm@numberpage@string@titleb{编\hspace{.5em}号\hspace{.5em}专\hspace{.5em}用\hspace{.5em}页}
\newcommand*\mcm@numberpage@string@appraiselog{赛区评阅记录(可供赛区评阅时使用):}
\newcommand\mcm@numberpage@string@reviewer{\shortstack{评\\ 阅\\ 人}}
\newcommand\mcm@numberpage@string@remarks{\shortstack{备\\ 注}}


\newcommand*\mcm@numberpage@string@countrynum{送全国评阅统一编号:\par \hspace*{2em}(赛区组委会填写)}
\newcommand\mcm@numberpage@string@inform{\quotation
\noindent({\bfseries\kai 请勿改动此页内容和格式。此编号专用页仅供赛区和全国评阅使用,参赛队打印后装订到纸质论文的第二页上。
注意电子版论文中不得出现此页。})
\endquotation
}
%设置目录格式
% 节的目录格式
% \titlecontents{section}[0pt]{\vspace{2mm}\bfseries}
% {\thecontentslabel\hskip.5em}{}{\titlerule*[0.5pc]{.}\contentspage}
% % 小节的目录格式
% \titlecontents{subsection}[30pt]{\songti}
% {\thecontentslabel\hskip.5em}{}{\titlerule*[0.5pc]{.}\contentspage}
% \titlecontents{subsubsection}[55pt]{\songti}
% {\thecontentslabel\hskip.5em}{}{\titlerule*[0.5pc]{.}\contentspage}

% 上标文献
\newcommand{\upcite}[1]{$^{\mbox{\scriptsize \cite{#1}}}$}
\newcommand{\supercite}[1]{\textsuperscript{\textsuperscript{\cite{#1}}}}
\endinput

虽然这个cumcmthesis.cls确实有点屎山吧,但生产力环境用起来的时候(比如三天的数模),可没有时间去修正和推倒从头来格式的编写。

多天尝试无果后,于是只好卸载MikTex,重新装回来了MacTex。与第一次浑浑噩噩得接触大为不同,这次算是终于初探LaTeX\LaTeXLATE​X本地配置。也算是折腾出了为什么会有这么多用户不约而同地在配置完成LaTeX\LaTeXLATE​X后写配置文档心得的缘由。一方面算是个记录,一方面,算是个reference。

TeX Live+VSCode的本地LaTeX\LaTeXLATE​X配置

  • 安装MacTex和VSCode。

    当然可以选择其他IDE,这都是个性化的。

  • 在VSCode的扩展商店中安装LaTeX Workshop插件

    LaTeX\LaTeXLATE​X的PATH应该是会自动配置的,Win和Mac上都一样,不需要额外的操作。

  • 参考了VSCode工作区的设定(当然这也可自定义)来自

    • 创建LaTeX\LaTeXLATE​X工作区
      首先,我们先创建一个空文件夹。名称可以自己命名,要求最好不含中文、空格,分词可以使用下划线_来分词。(好习惯)

      在VSCode中打开创建的文件夹,接着选择文件->将工作区另存为。

      我们把工作区保存在该文件夹目录下即可。

    • 配置工作区
      创建完工作区,我们就需要配置工作区,记住既然我们创建了工作区,那么所有的操作都在工作区内进行就可以了,切记不要去别的地方操作,那是没用的。

      将下述代码直接贴入.code-workspace文件中,下面我们再来谈谈这些代码的具体作用。

点击显示代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
{
"folders": [
{
"path": "."
}
],
"settings": {
"latex-workshop.latex.tools": [
{
"name": "xelatex",
"command": "xelatex",
"args": [
"-synctex=1",
"-interaction=nonstopmode",
"-file-line-error",
// "-pdf",
"%DOCFILE%"
]
},
{
"name": "pdflatex",
"command": "pdflatex",
"args": [
"-synctex=1",
"-interaction=nonstopmode",
"-file-line-error",
"%DOCFILE%"
]
},
{
"name": "makeindex",
"command": "makeindex",
"args": [
"%DOCFILE%.nlo",
"-s",
"nomencl.ist",
"-o",
"%DOCFILE%.nls"
]
},
{
"name": "biber",
"command": "biber",
"args": [
"%DOCFILE%"
]
},
{
"name": "bibtex",
"command": "bibtex",
"args": [
"%DOCFILE%"
]
}
],
"latex-workshop.latex.recipes": [
{
"name": "xelatex🔃",
"tools": [
"xelatex"
]
},
{
"name": "xe->mkind->bib->xe*2🔃",
"tools": [
"xelatex",
"makeindex",
"biber",
"xelatex",
"xelatex"
]
},
{
"name": "pdf->mkind->bib->pdf*2🔃",
"tools": [
"pdflatex",
"makeindex",
"biber",
"pdflatex",
"pdflatex"
]
},
{
"name": "xe->bib->xe->xe🔃",
"tools": [
"xelatex",
"bibtex",
"xelatex",
"xelatex"
]
},
{
"name": "biber🔃",
"tools": [
"biber"
]
},
{
"name": "pdflatex🔃",
"tools": [
"pdflatex"
]
},
{
"name": "pdf->bib->pdf->pdf🔃",
"tools": [
"pdflatex",
"bibtex",
"pdflatex",
"pdflatex"
]
},
{
"name": "BibTeX🔃",
"tools": [
"bibtex"
]
}
],
"latex-workshop.showContextMenu": true,
"latex-workshop.view.pdf.viewer": "tab", //使用 VSCode 内置标签页 PDF 查看器
"latex-workshop.latex.synctex.path": "synctex",
"latex-workshop.view.pdf.ref.viewer": "tab",
"latex-workshop.latex.recipe.default": "lastUsed", // 使用上次的编译方式
"editor.wordWrap": "on", //VSCode 的全局编辑器设置,自动换行功能
"latex-workshop.synctex.synctexjs.enabled": false, // 禁用 JavaScript SyncTeX
"latex-workshop.synctex.afterBuild.enabled": true, // 构建后启用 SyncTeX
"latex-snippets.autoSuggestionOn": true, //LaTeX 代码片段(snippets)的自动建议设置,在编写 LaTeX 文档时自动提供代码片段建议
}
}

在使用 LaTeX\LaTeXLATE​X 编译文件时,.synctex.gz文件是 SyncTeX 同步功能生成的压缩文件。这个文件主要用于文本编辑器和 PDF 阅读器之间的正向和反向同步。上述配置已经确保在编译 LaTeX\LaTeXLATE​X 时添加 -synctex=1 选项,这样可以实现源代码和 PDF 之间的双向跳转。

在需要双向跳转的情况下,务必保留这个文件。构建LaTeX项目下的清理辅助文件会保留该文件。

解释部分没啥重复撰写的必要,就再引用一下:

latex-workshop.latex.tools这里面主要配置的就是各种编译方式,我们最常用到的就两种xelatex和bibtex(注意不是biber),有时候也会用到pdflatex。一开始,我一直都无法编译.bib的参考文献,原因就出在编译链使用 的是biber,而非bibtex,所以我就改了。

latex-workshop.latex.recipes这里面就是所谓的编译链了。我们知道LaTeX生成PDF的原理就是使用编译器进行编译。一般的文件我们只需要使用一次或两次xelatex即可编译成功;而当我们有含.bib的参考文献时,一般的编译链就变成,编译一次xelatex,一次bibtex,两次xelatex,也就是上述编译链中的"xe->bib->xe->xe🔃"。

其实还有编译包括目录的文档的时候也需要两次编译,两次编译期间不要清理辅助文件。以及显然,latex-workshop.latex.recipes的每个recipe名字可以更改。

  • 单击SyncTeX from cursor即可正向搜索。

  • 反向同步的内部查看器:ctrl/cmd +点击(默认)或双击

总之,一般情况下,纯英文tex使用配方:pdflatex🔃;中文tex使用配方:xe->bib->xe->xe🔃。

突然想起来,我看了一下我的用户settings.json,发现自己vscode下的’/Users/xxx/Library/Application Support/Code/User/settings.json’似乎之前配置过了😅。没事,这个当作全局,上面的当作工作区。要是不想搞全局的用户设置也无妨。(或者说反过来也无妨。看个人软件设置的偏好,喜欢全局还是单个工作区单个设定,自己别搞混就行)

点击显示代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
{"latex-workshop.latex.tools": [	
{
"name": "pdflatex",
"command": "pdflatex",
"args": [
"-synctex=1",
"-interaction=nonstopmode",
"-file-line-error",
"%DOCFILE%"
]
},
{
"name": "xelatex",
"command": "xelatex",
"args": [
"-synctex=1",
"-interaction=nonstopmode",
"-file-line-error",
"%DOCFILE%"
]
},
{
"name": "bibtex",
"command": "bibtex",
"args": [
"%DOCFILE%"
]
}
],
"latex-workshop.latex.recipes": [
{
"name": "xelatex",
"tools": [
"xelatex"
],
},
{
"name": "pdflatex",
"tools": [
"pdflatex"
]
},
{
"name": "xe->bib->xe->xe",
"tools": [
"xelatex",
"bibtex",
"xelatex",
"xelatex"
]
},
{
"name": "pdf->bib->pdf->pdf",
"tools": [
"pdflatex",
"bibtex",
"pdflatex",
"pdflatex"
]
}
],
"latex-workshop.latex.clean.fileTypes": [
"*.aux",
"*.bbl",
"*.blg",
"*.idx",
"*.ind",
"*.lof",
"*.lot",
"*.out",
"*.toc",
"*.acn",
"*.acr",
"*.alg",
"*.glg",
"*.glo",
"*.gls",
"*.ist",
"*.fls",
"*.log",
"*.fdb_latexmk"
],
//tex文件浏览器,可选项为"none" "browser" "tab" "external"
"latex-workshop.view.pdf.viewer": "tab",
//自动编译tex文件
"latex-workshop.latex.autoBuild.run": "onFileChange",
//显示内容菜单:(1)编译文件;(2)定位游标
"latex-workshop.showContextMenu": true,
//显示错误
"latex-workshop.message.error.show": false,
//显示警告
"latex-workshop.message.warning.show": false,
//从使用的包中自动补全命令和环境
"latex-workshop.intellisense.package.enabled": true,
//设置为never,为不清除辅助文件
"latex-workshop.latex.autoClean.run": "never",
//设置vscode编译tex文档时的默认编译链
"latex-workshop.latex.recipe.default": "lastUsed",
// 用于反向同步的内部查看器的键绑定。ctrl/cmd +点击(默认)或双击
"latex-workshop.view.pdf.internal.synctex.keybinding": "double-click",
"dart.flutterSdkPath": "/Users/victor/development/flutter",
"editor.unicodeHighlight.ambiguousCharacters": false,

}

我又看了看,这个原先的全局配置是有些考虑不周的,比如没有双向同步等。这个全局配置还是别看了,直接用工作区的配置文件把这个全局的覆盖掉吧。直接覆盖记得删去

1
2
3
4
5
6
7
8
9
10
{
"folders": [
{
"path": "."
}
],
"settings": {
pass

}

其他事项

主要配置就完成了,一些注意事项:

  • LaTeX Workshop 默认的编译工具是 latexmk,一般不需要用到。

  • tools 中使用 %DOC% 而非 %DOCFILE% 是考虑到支持编译中文路径下的文件。

  • 第一个 recipe 为默认的编译工具

引文还提到了以下这些,不过我没有应用:

  • 快捷键设置
    在 VSCode 界面下按下 F1,键入“keyjson”,选择“打开键盘快捷方式(JSON)”,然后把以下代码放入:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
"key": "alt+s",
"command": "latex-workshop.synctex",
"when": "editorTextFocus && !isMac"
},
{
"key": "alt+b",
"command": "latex-workshop.build",
"when": "editorTextFocus && !isMac"
},
{
"key": "alt+t",
"command": "latex-workshop.kill",
"when": "editorTextFocus && !isMac"
},
{
"key": "alt+e",
"command": "latex-workshop.recipes"
},

这段代码的意义是将 Alt+s 绑定到正向搜索,将 Alt+b 绑定到使用默认 recipe 编译,将 Alt+t 绑定到终止编译,将 Alt+e 绑定到选择其他 recipe 编译,可以自行更换为适合自己的快捷键,只需修改“key”那一项即可。

  • 其他设置
    LaTeX Workshop 默认保存的时候自动编译,如果不喜欢这个设置,可以添加以下代码进入设置区:
1
"latex-workshop.latex.autoBuild.run": "never",

如果编译出错,插件会弹出两个很烦人的气泡,不喜欢的话可以在设置中添加以下代码:

1
2
"latex-workshop.message.error.show": false,
"latex-workshop.message.warning.show": false,

又及:

part1:ctex & xeCJK

ctex 和 xeCJK 的主要区别如下:

  1. 功能范围:
  • xeCJK 是一个基础的中文支持包,主要处理中文字体和标点符号的显示
  • ctex 是一个更全面的中文排版工具集,它在 xeCJK 的基础上提供了更多功能
  1. 开箱即用程度:
  • xeCJK 需要手动配置字体和其他排版参数
  • ctex 提供了预设的中文排版格式,包括字体配置、版式设置等
  1. 具体功能对比:

xeCJK:

1
2
\usepackage{xeCJK}
\setCJKmainfont{Songti SC} % 必须手动设置字体
  • 基础的中文支持
  • 字体设置
  • 标点符号处理
  • 中英文间距调整

ctex:

1
\usepackage[UTF8]{ctex}  % 自动配置大部分设置
  • 包含 xeCJK 的所有功能
  • 自动配置中文字体
  • 章节标题的中文格式
  • 中文版式设置(如标点悬挂)
  • 中文数字转换
  • 提供文档类(ctexart、ctexbook 等)
  1. 使用场景:
  • 如果只需要在英文文档中插入少量中文:用 xeCJK 够用
  • 如果要编写完整的中文文档:建议用 ctex
  1. 举例说明:
    使用 xeCJK:
1
2
3
4
5
6
7
\documentclass{article}
\usepackage{xeCJK}
\setCJKmainfont{Songti SC}
\begin{document}
第一章 介绍
这是一个测试文档。
\end{document}

使用 ctex:

1
2
3
4
5
\documentclass{ctexart}  % 或者用 \usepackage{ctex}
\begin{document}
第一章 介绍
这是一个测试文档。
\end{document}

一般建议:

  • 对于正式的中文文档,优先使用 ctex,它能处理好大多数中文排版细节
  • 如果遇到特殊需求或者想要更精细的控制,可以使用 xeCJK
  • 在一些简单的场景下,如果 ctex 配置有问题,也可以退而求其次使用 xeCJK

part2:ctexart & article

\documentclass[UTF8]{ctexart} 和 \documentclass{article} 有以下主要区别:

  1. 字体和中文支持:
  • ctexart:自动配置中文支持,包含中文字体设置和标点符号处理
  • article:默认只支持英文,需要手动添加中文支持包(如 xeCJK 或 ctex)
  1. 章节标题格式:
  • ctexart:使用中文格式的章节标题(如"第一章")
  • article:使用英文格式的章节标题(如"Chapter 1")
  1. 页面布局:
  • ctexart:采用适合中文排版的页面设置(如行距、段落间距等)
  • article:使用西文排版的标准设置
  1. 文档结构:
  • ctexart:比如 \maketitle 会生成中文格式的标题页
  • article:生成英文格式的标题页

例子:

使用 article:

1
2
3
4
5
6
7
8
9
10
11
12
13
\documentclass{article}
\usepackage{xeCJK} % 需要手动添加中文支持
\setCJKmainfont{Songti SC}

\title{测试文档}
\author{张三}
\date{\today}

\begin{document}
\maketitle
\section{引言}
这是一个测试。
\end{document}

使用 ctexart:

1
2
3
4
5
6
7
8
9
10
11
\documentclass[UTF8]{ctexart}

\title{测试文档}
\author{张三}
\date{\today}

\begin{document}
\maketitle
\section{引言}
这是一个测试。
\end{document}

所以,对于中文文档:

  • 如果是以中文为主的文档,建议使用 ctexart
  • 如果是以英文为主、偶尔包含中文的文档,可以使用 article

后续会继续完善自己的LaTeX\LaTeXLATE​X知识库。

又及:也是事情多了,记性差了。一翻找文件夹才发现暑假之前6月就整理过好多LaTeX\LaTeXLATE​X的配置和要点了,后来只顾着写文本就淡却了,不过一翻,还是记起来了~😌

本文更像是心理历程,初学者直接照此配置可能不太清晰,可以多读读参考链接,就有大概思路了熟悉了。

参考文献:

Levitate_.如何优雅的书写LaTeX论文.https://levitate-qian.github.io/2020/07/21/latex-vscode

Marvey.使用VSCode编写LaTeX[EB/OL].https://zhuanlan.zhihu.com/p/38178015

Liam Huang.TeX Live 下载及安装说明.https://liam.page/texlive/

董晟渤.Visual Studio Code配置LaTeX教程.https://dylandong.top/posts/54e5/

CTEX开发小组.一份(不太)简短的LaTeX2e\LaTeX2eLATE​X2e介绍.https://github.com/CTeX-org

韬秧道.MacTeX 配合 Visual Studio Code 进行 LaTeX 写作.https://blog.tauyoung.top/about/

Share 

 Previous post: Python虚拟环境配置与使用教程deepseek Next post: encoding 

© 2025 Victor

Theme Typography by Makito

Proudly published with Hexo