2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

エラーしながら学ぶVSCodeにLatexを導入2

Last updated at Posted at 2022-12-20

こちらは、前回の続きとなっています。遅くなって申し訳ありません。

これは Windowsユーザー向け のVSCodeに少し変わったLaTeX導入方法です。

VSCodeで、latexの環境構築をする方法はたくさんあってネットで調べた限りでは、latexmk+LaTeXWorkshop, latexmkなし+LaTeXWorkshop, Makefileのようないろいろな方法がありました。
今回は、latexmk+LaTeXWorkshopの方法でやります。

前回を見ていない人はこちらへどうぞ。

前回は$\TeX$が動くようになったので、今回は$\TeX$の日本語パッケージやコマンドの使い方などを教えたいと思います。

日本語パッケージの導入

前回の$\TeX$環境ままだと英語の論文は書けますが、私たちの母語は日本語なので日本語パッケージを入れなければなりません。

今回使うコマンドは、tlmgrというTeXLive のパッケージ管理をするツールです。
Pythonを使ったことがある人ならわかると思いますが、pipと同じようなものです。

では、早速入れてみましょう。

1. 管理者権限でターミナルを開く

img.png

2. 次のコマンドを打ち込む

tlmgr install collection-langjapanese collection-mathscience collection-pictures here float texdoc

3. ダウンロードでき終わるまで長いので待つ

これで日本語パッケージが入っているはずです。
これでも入らなかったら、前回に戻って環境変数のPATHをもう一度見直してみてください。

seikou.png

コマンドでTeXを出力

コマンドの使い方を知っている人なら何でこんなことやるの?って思う人がいるかと思うけど、TeXの質問をするサイト で環境構築のことについて質問している人で、いきなりVSCodeで出力させてエラーが出てきてわからないという方が多く見受けられたからです。

VSCodeによる自動コンパイルが使えなかったら一旦コマンドで打つようにしましょう

少し面倒かと思うけど頑張ってみてください。
では、まず最初にLua$\LaTeX$からやってみましょう。

LuaLaTeXをコマンドで出力

1. わかりやすいところに新規ファイルを作り、ファイル内で右クリックをしてターミナルを開く
fail.png

2. 前回入れたVSCodeがあるはずなので、以下のコマンドで実行する

code . luasample.tex

luasample.png

3. こちらをコピーし、開かれたVSCodeに張り付ける

luasample.tex
\documentclass[a4paper,11pt]{ltjsarticle}

% フォント
\usepackage{amsmath,amsfonts}

\begin{document}

\title{\LaTeX の使い方}
\author{\TeX Taro}
\date{\today}
\maketitle

\section{序論}
Lua\LaTeX の使い方を軽く学ぼう。

\subsection{数式を書いてみよう}
運動方程式を書いてみる
\begin{eqnarray}
  ma = F
\end{eqnarray}

\end{document}

4. 赤い丸をしたところにluasample.texがあることを確認して、VSCodeのターミナルに以下のものを実行する。

lualatex luasample

vscode.png

5. エラーが出ないはずなので、そこのファイルにpdfができているので確認する
latex.png

これで基本的にLua$\LaTeX$は使えます。次に、up$\LaTeX$を使ってみましょう。

前回、Lua$\LaTeX$の利点として、中間ファイルであるdviファイルがでないため工程が少なくなる。ということを言いました。
つまり、up$\LaTeX$は中間ファイルを挟むので少し面倒だということでやってみましょう。

upLaTeXをコマンドで出力

1. VSCodeからupsample.texを新規作成する
uplatex.png

2. 以下のコードをupsample.texに張り付ける

upsample.tex
\documentclass[a4paper,11pt,uplatex]{jsarticle}

% 数式
\usepackage{amsmath,amsfonts}

\begin{document}

\title{\LaTeX の使い方}
\author{\TeX Taro}
\date{\today}
\maketitle


\section{序論}
up\LaTeX の使い方を軽く学ぼう。

\subsection{数式を書いてみよう}
ラマヌジャンが見つけた等式
\begin{eqnarray}
  \frac{1}{\pi} = \frac{2\sqrt{2}}{99^2} \sum_{n=0}^\infty \frac{(4n)!}{(n!)^4} \frac{26390n+1103}{396^{4n}}
\end{eqnarray}

\end{document}

3. VSCodeのターミナルに以下のものを実行する

uplatex upsample

4. pdfではなくdviファイルができていることを確認する。
dvipdfmk.png

5. dviをpdfに変える次のコマンドを実行する

dvipdfmx upsample

6. pdfができていることを確認する。

コマンドで出力のまとめ

何度でも言いますが、

VSCodeによる自動コンパイル使えなかったら一旦コマンドで打つようにしましょう

論文とかを見てみると、最後のほうに参考文献とかがいっぱい載っているのを見たことがあると思います。
それは、BibTeXというものを使っていて、これのコマンドで入力する場合(up$\LaTeX$)

uplatex hoge # auxファイルを作る
pbibtex hoge # bblファイルを作る
uplatex hoge # bblファイルを取り込む
uplatex hoge # dviを作成する
dvipdfmx hoge # dviをpdfにする

のようになってとても大変である。

そのようなことを避けるためにLatexmkというコマンドがあるのでそれを使って、自動でコンパイルできるようにしましょう。

VSCodeの拡張機能を入れる

LaTeXWorkshopとは、VSCodeでpdfが見れるようになったり、ボタン一つでコンパイルできるようになったりとてもすごいやつ。

1. LaTeXWorkshopを入れる (ついでにVSCodeの日本語パッケージが入っていなかったら入れておきましょう)
latexworkshop.png

2. setting.jsonを開く
setiingjson.png

3. setting.jsonに以下のコードを書く(そこに何か書かれていたら特徴を観察してみて追加してみてください。エラーがなくなるまで頑張ってください。)

setting.json
{
  // ----------   LaTex  ----------
  "[tex]": {
    // スニペット補完中にも補完を使えるようにする
    "editor.suggest.snippetsPreventQuickSuggestions": true,
    // インデント幅を2にする
    "editor.tabSize": 2,
    // editor.wordSeparators: 単語単位での移動を行う場合の区切り文字を指定
    // 日本語文書で単語移動を使うため、助詞や読点、括弧を区切り文字として指定する
    "editor.wordSeparators": "./\\()\"'-:,.;<>~!@#$%^&*|+=[]{}`~? 、。「」【】『』()!?てにをはがのともへでや",
  },
  "[latex]": {
    "editor.suggest.snippetsPreventQuickSuggestions": true,
    "editor.tabSize": 2,
    "editor.wordSeparators": "./\\()\"'-:,.;<>~!@#$%^&*|+=[]{}`~? 、。「」【】『』()!?てにをはがのともへでや",
  },
  "[bibtex]": {
    "editor.tabSize": 2,
  },

  // 使用パッケージのコマンドや環境の補完を有効にする
  "latex-workshop.intellisense.package.enabled": true,  
  // 生成ファイルを "out" ディレクトリに吐き出す
  "latex-workshop.latex.outDir": "out",

  // latex-workshop.latex.tools: Tool の定義
  "latex-workshop.latex.tools": [
      // latexmk を利用した lualatex によるビルドコマンド
      {
        "name": "Latexmk (LuaLaTeX)",
        "command": "latexmk",
        "args": [
          "-gg", "-pv", "-synctex=1", "-lualatex", "-file-line-error","-outdir=%OUTDIR%", "%DOC%"
        ]
      },
      // latexmk を利用した uplatex によるビルドコマンド
      {
        "name": "Latexmk (upLaTeX)",
        "command": "latexmk",
        "args": [
          "-gg", "-pv", "-synctex=1", "-file-line-error", "-outdir=%OUTDIR%", "%DOC%"
        ]
      },
      // latexmk を利用した platex によるビルドコマンド
      // 古い LaTeX のテンプレートを使いまわしている (ドキュメントクラスが jreport  jsreport ) 場合のため
      {
        "name": "Latexmk (pLaTeX)",
        "command": "latexmk",
        "args": [
          "-gg", "-pv", "-latex='platex'", "-latexoption='-kanji=utf8 -no-guess-input-env'", "-synctex=1", "-file-line-error","-outdir=%OUTDIR%", "%DOC%"
        ]
      },
      // latexmk を利用した xelatex によるビルドコマンド
      {
        "name": "Latexmk (XeLaTeX)",
        "command": "latexmk",
        "args": [
          "-gg", "-pv", "-xelatex", "-synctex=1", "-interaction=nonstopmode", "-file-line-error", "-outdir=%OUTDIR%", "%DOC%"
        ]
      },
      // 透過された数式作成のためのコマンド
      {
        "name": "latexmkout",
        "command": "latexmk",
        "args": [
          "-gg", "-silent", "%DOC%",
        ],
      },
      // 透過された画像用のpdfのトリミング
      {
        "name": "pdftrimming",
        "command": "pdfcrop",
        "args": [
          "%DOC%.pdf", "%DOC%.pdf",
        ]
      },
      // pdfを透過された画像に変換
      { 
        "name": "pdf2png",
        "command": "pdftocairo",
        "args": [
          "-png", "-r", "300", "-transp", "%DOC%.pdf"
        ]
      },
  ],

  // latex-workshop.latex.recipes: Recipe の定義
  "latex-workshop.latex.recipes": [
      // LuaLaTeX で書かれた文書のビルドレシピ
      {
        "name": "LuaLaTeX",
        "tools": [
          "Latexmk (LuaLaTeX)"
        ]
      },
      // LaTeX(upLaTeX) で書かれた文書のビルドレシピ
      {
        "name": "upLaTeX",
        "tools": [
          "Latexmk (upLaTeX)"
        ]
      },
      // XeLaTeX で書かれた文書のビルドレシピ
      {
        "name": "XeLaTeX",
        "tools": [
          "Latexmk (XeLaTeX)"
        ]
      },
      // LaTeX(pLaTeX) で書かれた文書のビルドレシピ
      {
        "name": "pLaTeX",
        "tools": [
          "Latexmk (pLaTeX)"
        ]
      },
      // パワポ用に透過された数式の画像の出力
      {
        "name": "tex2png",
        "tools": [
          "latexmkout",
          "pdftrimming",
          "pdf2png",
        ]
      },
  ],

  // latex-workshop.latex.magic.args: マジックコメント付きの LaTeX ドキュメントをビルドする設定
  // '%!TEX' で始まる行はマジックコメントと呼ばれ、LaTeX のビルド時にビルドプログラムに解釈され、
  // プログラムの挙動を制御する事ができる。
  "latex-workshop.latex.magic.args": [
    "-f", "-gg", "-pv", "-interaction=nonstopmode", "-file-line-error", "%DOC%"
  ],
  // latex-workshop.latex.clean.fileTypes: クリーンアップ時に削除されるファイルの拡張子
  // LaTeX 文書はビルド時に一時ファイルとしていくつかのファイルを生成するが、最終的に必要となるのは
  // PDF ファイルのみである場合などが多い。また、LaTeX のビルド時に失敗した場合、失敗時に生成された
  // 一時ファイルの影響で、修正後のビルドに失敗してしまう事がよくある。そのため、一時的なファイルを
  // 削除する機能 (クリーンアップ)  LaTeX Workshop には備わっている。
  "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", "*.synctex.gz",
      // for Beamer files
      "_minted*", "*.nav", "*.snm", "*.vrb",
  ],

  // latex-workshop.latex.autoBuild.run: .tex ファイルの保存時に自動的にビルドを行うかどうか
  "latex-workshop.latex.autoBuild.run": "onSave",

  // ----------   LaTex END  ----------  
}

参考先

ase.png

軽くsetting.jsonが何をやっているかの説明

latex-workshop.latex.tools

まず、latex-workshop.latex.toolsから説明する。

"latex-workshop.latex.tools": [
      // latexmk を利用した lualatex によるビルドコマンド
      {
        "name": "Latexmk (LuaLaTeX)",
        "command": "latexmk",
        "args": [
          "-gg", "-pv", "-synctex=1", "-lualatex", "-file-line-error","-outdir=%OUTDIR%", "%DOC%"
        ]
      },

これは、次のコマンドにいろいろなオプションをつけまくっている感じで、。

latexmk hoge

ここの中で、好き嫌いが出るオプションは"-synctex=1"で、これはSumatraPDFのような一部のPDFreaderがコマンド実行時に自動で開くオプションです。
「VSCodeで、PDFを見るわ」っていう人は消してもらって構わないです。

latex-workshop.latex.recipes

次のサンプルが一番わかりやすい

"latex-workshop.latex.recipes": [
      // パワポ用に透過された数式の画像の出力
      {
        "name": "tex2png",
        "tools": [
          "latexmkout",
          "pdftrimming",
          "pdf2png",
        ]
      },

latex-workshop.latex.toolsで定義されたコマンドである"latexmkout"、"pdftrimming"、"pdf2png"をこの順番で実行している。

tex2pngは、TeXclipのような透過された数式の画像ができるものである。
いらなかったら"latexmkout"、"pdftrimming"、"pdf2png"、"tex2png"を消してください。

続きのリンク

環境構築ってとても大変ですね。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?