8
5

やりたいことから始めるTypst

Last updated at Posted at 2024-05-29

はじめに

この記事はTypstの初心者向け解説です.
すでにマニュアルは複数ありますが,typst.appを用いた解説は筆者の知る限り日本語では存在しません(2024/5/29現在).

プログラミングもよく知らない人にも扱えるように書いたつもりです.

Typstで作ったpdf版は以下にあります

Typstを始めたい

https://typst.app/ にアクセスして,sign upをしてください.メールは実際のメールアドレスであればなんでもOKです.名前もなんでも良いです.select where you heard about Typstはクリックして適当なものを,TelemetryはEnabledをクリックして左下のSign upをしてください.

typst.png

なお,internet exploreではうまくいかないようなので,chromeなどでやってください.それでもうまくいかないときはキャッシュやクッキーを削除したりテキトーにブラウザを変えたり,ゲストで行くとうまくいく場合があります.(「キャッシュやクッキーを削除」の意味がわからない人はそう検索してください)

サインアップに成功すると以下のようなメニューが出ますので Empty documentを選んでください.

typst2.png

すると以下のようなメニューがでますのでプロジェクト名を適当に決めてください.なんでも良いです.

menu.png

すると,以下のような画面が出ます.

document.png

文章を書きたい

以下のように左側の部分に適当に文字を打ってみましょう.それは右側にそのまま現れるはずです.

docu2.png

左側が,どんな文章を書くかの命令をする部分で,右側が命令をした結果の部分です.このようにTypstはプログラミングをするかのように文章を作成できます.それの何が便利なのかは以下を見ていってください.

見出しを書きたい

次のように打ってみてください,見出しが現れます.

= 見出し

=の数を増やすと見出しが細かくなります.以下のようにしてみましょう.

== 小見出し

ところで見出しに番号がありません.そんなときは

#set heading(numbering: "1.1.")

と打ってみましょう.そうするとこの文章のように,見出しに1.と番号がつきます.

番号の種類はいろいろあります.例えば以下のようにしてみましょう

#set heading(numbering: "I.i.")

そうすると,見出しの番号がローマ数字になります.

ちなみに以下のようにすると見出しのフォントを変えられます

#show heading: set text(font: "Harano Aji Gothic")

箇条書きをしたい

箇条書きをするには-と打って,スペースを押してください.例えば以下のようなコードを書いてみましょう.

- こんなふうに箇条書きになるはずです.
- 箇条書きを並べていきます
  - タブキーを押して,-の前にスペースを入れると箇条書きのレベルが下がります.

すると出力は次のようになります.

スクリーンショット 2024-05-29 12.19.19.png

  • -の代わりに+を使うと番号のついた箇条書きを作成できます.
    • 番号のついていない箇条書きと同様にレベルが一つ下がります.
  • 箇条書きの番号を変更するには以下のようにします
    #set enum(numbering:"1.a.")
    

#set enum(numbering:"1.a.")

  • すると,レベル2以降の箇条書きがアルファベットになります

    • 注意したいのは,プログラミングは上から下に読んでいくので,設定は#set 〜と書いた以降の行から反映されます.
  • ところで,何か文字を打ってから行を一つ空けてしまうと,番号は数え直しになります. 

  • 途中から番号を数えたい時は#set enum(start: 4)とすると,途中の番号から数えてくれます.

箇条書きは以下のように書くこともできます.

#set enum(start: 1)
#enum([第1項目],
      [第二項目],
      [サブ項目 
          #enum([第a項目],
                [第b項目]
                )],
      [第4項目]
      )

スクリーンショット 2024-05-29 12.20.38.png

文字を中央に置きたい

普通に文字を書いていると,文章は左から始まります.しかし,タイトルは中央に置きたいでしょう.そんなときは,以下のようにします.

#align(center)[タイトル]

こうすることで,[]の中の文章を中央に配置することができます.ちなみにcenterをleftやrightに変えるとどうなるかやってみてください.

数式を書きたい.

$$で囲んだ領域は「数式モード」になります.
たとえば, $f'(x)=x^3$という出力をするには f'(x)=x^3と入力します.

インライン数式とディスプレイ数式

数式には「文中数式(インライン数式)」と「ディスプレイ数式」というものがあり,例えば文中に出てくる$x_2$というのが文中数式です. 入力は以下のようにします

例えば文中に出てくる$x_2$というのが文中数式です.

一方でディスプレイ数式は,文章とは独立の段落で描かれる数式で,以下のようなものです.

スクリーンショット 2024-05-29 12.21.53.png

これは以下のように書きます.

$
integral_0^1 x f(x) dif x
$

$$の間にスペースを入れるか,改行を行うとディスプレイ数式扱いとなります.

以下は主な数式の例をリストアップしています.

スクリーンショット 2024-05-29 12.22.26.png

使用できる記号は以下のサイトで手書きで検索できます.
https://detypify.quarticcat.com/

数式に番号を振りたい

以下のようにすれば, set〜とした下の行から,数式に番号がつきます.

#set math.equation(numbering: "(1)")
$
x^2 = integral_0^x f(z)dif z
$
$
x^2 = sum_(z = 0)^x f(z)
$

これをすると,以下のようになります.
スクリーンショット 2024-05-29 12.22.56.png

数式を = の位置で揃えたい

以下のようにすれば,&のところで揃えられます.

$
f(x) &= x(x-1)\
     &= x^2-x
$

以下が出力です.
スクリーンショット 2024-05-29 12.23.25.png

数式フォントを変えたい

以下のようにします.

#show math.equation: set text(font:"フォント名")

以下では typst.app で使用できる数式フォントを紹介します.

スクリーンショット 2024-06-03 14.54.06.png

その他細かい注意

  • $a/b$ のように文中の分数にしたいときは $a slash b$あるいは $a \/ b$というようにします. \はエスケープ記号で,それを前につけることで特殊機能の記号をそのまま出力します.

  • $colon$と書いても$:$と書いてもスペースは変わりません. 一方で集合差を書くときは $X without Y$とします.これは $X backslash Y$と若干違います.

  • 条件付き確率のように$P(x \mathrel{|} y)$と書きたいときは$P(x | y)$のように|の周りにスペースを開けるだけでOKです. $P\left(\sum \middle| \frac{y}{x}\right)$というようにしたい場合は$P(sum mid(|) y/x)$とします.

  • 数式モードの外で数式を使いたいときは,例えば #math.alphaのように#math.を数式命令につけます.

  • その他記号を探すときにはdetexifyのtypstバージョンである https://detypify.quarticcat.com/ が便利です.

  • より詳細は次のページをご覧ください. https://typst.app/docs/reference/math/ referenceには次の項目があります.

    • Accent
    • Attach
    • Cancel
    • Cases
    • Class
    • Equation
    • Fraction
    • Left/Right
    • Matrix
    • Primes
    • Roots
    • Sizes
    • Styles
    • Text Operator
    • Under/Over
    • Variants
    • Vector

表を書きたい

表を作るには以下のようにします.

#table(columns: 2,
  [A],[B],
  [C],[D])

すると次のような表を作ることができます.

スクリーンショット 2024-05-29 12.23.52.png

columns: 2というので列の数を指定しています.このcolumnsにそれぞれの列の長さを指定することで,表の列の長さを指定できます.
例えば次のようにしてみましょう.

#table(columns: (2em, 1fr),
  [A],[B],
  [C],[D])

すると次の表が書けます.

スクリーンショット 2024-05-29 12.24.12.png

これは1列目を#{2em}という長さ(#{1em}はmの横幅です),2列目をページの横幅いっぱいまで伸ばすという意味になります.#{1fr}を複数の列で使えば,長さは均等割されます.以下がその例です.

#table(columns: (2em, 1fr, 1fr),
 [A],[B],[d],
 [C],[D],[z])

すると次の表が書けます.

スクリーンショット 2024-05-29 12.24.38.png

表はかなり自由にカスタマイズできるので,より詳しくは本家の解説を見てください.
https://typst.app/docs/guides/table-guide/

太字や斜体にしたい

太字にするには*太字*とします. 斜体は_斜体_とします.

文字の大きさやフォントを変えたい

文字の大きさを変えるには#text(size:12pt)[12ptの文字]とすると文字の大きさを変えることができます.大きい文字にしたい時はそのように変えてください.

フォントを変えるには以下のように書いてみましょう.

#set text(font: "Harano Aji Mincho")

この行を書いた下の行からフォントが原ノ味明朝体というフォントに変わります.フォントは好きなフォントをアップロードして上のように書けば変えることができます.

文字の色を変えたい

文字の色を変えるには #text(fill: rgb("#4169e1"))[カラー]とやってみましょう.どんな色が出るのかをみてみてください.
rgbは色を指定するコードです.どの色がどのコードに対応しているかはたとえば以下のサイトで調べられます.

red,blue,greenなどの以下にある色は,rgbと書かなくてもそのまま指定できます.

color.png

下線を引きたい

下線を引くには#underline[下線を引く]とします.

脚注を作りたい

以下のようにしてみましょう

これが脚注#footnote[脚注の中身]

リンクを張りたい

リンクを張るには次のようにします.

#link("Webページのurl")[表示する文字]

例えば以下のページのリンクを張ってみましょう

リンクのフォントを変更するには次のようにします.例えば以下の例は色を変更しています.

#show link: set text(fill: blue)

段落の最初を字下げしたい

この文章を見てみると,段落の字下げがされていません.これは気持ち悪いという人は以下のようにしてみてください

#set par(first-line-indent: 1em)

ちなみに見出し直後の最初の段落は字下げされませんがこれはバグだそうです.

par というのはパラグラフ(段落)のことでこれをカスタマイズする設定です.

既存の関数をカスタマイズしたい

既存の関数だと気に入らない場合は次のようにしてみましょう.例えば,太字のフォントが気に入らないとします.そんなときは次のようにしてみましょう.

#show strong: it => text(font: "Harano Aji Gothic")[#it]

変わりましたか? ちなみにこうするとこの行以降は全部変わってしまうので注意してください.

ページ番号をつけたい/余白を設定したい

ページ番号をつけるには,以下のようにします.そうすると,書いた次のページからページ番号がつきます. (ページが変わることに注意!)

#set page(numbering: "1")

こうするとページが変わってしまうので,この命令は一番最初に書くのが吉です.

ページの余白を設定するには,次のようにしましょう.カッコの数に注意してください.

#set page(margin: (top: 1.5cm, bottom: 1.5cm,left:1.5cm,right:1.5cm))

やはりページが変わってしまいますが,余白は変更されます.

なお,手動でページを改めるには#pagebreak()と打ちます.

目次を書きたい

#outline()とタイプすることで目次を表示できます.
次のように引数を適宜調整すると見た目が変わります.

#outline(title: "目次",depth: 1)

省略したい

#letをつかうと自作の関数を作ることができます.例えば,文字を赤くしたいが,毎回textなんちゃらと書くのは面倒だというときはこうしましょう

#let aka(body) = {text(fill: red)[#body]}
#aka[あか]

ここのakaが関数の名前で,他と被らなければこれは別になんでも良いです.日本語っぽいものの方が他と被らないのでそうする利点はあります(ただし他の人が見ると分かりにくい!).
bodyの部分は関数の[]で括った部分に対応します.

また,長々しい文章を#letをつかって省略することができます.
以下でやってみましょう

#let juge = {"寿限無 寿限無 五劫のすりきれ 海砂利水魚の水行末雲来末 風来末食う寝るところに住むところ やぶらこうじのぶらこうじ パイポパイポ パイポのシューリンガン シューリンガンのグーリンダイ グーリンダイのポンポコピーのポンポコナーの長久命の長助"}
#juge が転んで怪我をしただって? #juge は絆創膏が欲しいって. #juge はどこにいるんだ? #juge は庭先にいるよ. #juge を呼んできてくれ. #juge はもう血は止まったって.

自作の関数を作りたい

ある程度の機能は自分で実装することができます.たとえば,数式に番号をつけたり外したりしたい時があるとしましょう.この場合つけたい時には

#set math.equation(numbering:"(1)") 

つけたくない時には

#set math.equation(numbering:none) 

とすればいいわけですが,これは面倒ですので,例えば次のようにしてみます.

#let eq_no(equation) = {
set math.equation(numbering: none) 
equation
}
#eq_no[$
x^2-x=x(x-1)
$]
$
x^3-x^2=x^2(x-1)
$

文字を入れ替えたい

以下の文章を書いてみましょう.打った文章と右側に出てきた文章でどう違うか比べてみましょう.

#show "ラーメン": "青汁"  
#show "悪い": "良い"
ラーメンはとても健康に悪い

コメントアウトしたい

//と打った後の文字列は灰色になり,その文字列は表示されません.これは「コメントアウト」という機能です.実際の文章には反映させませんが,どうやるかのメモとして残しておくのに便利です.

画像を挿入したい

以下の図のような左上のボタンを押すと,このプロジェクトのフォルダが開きます
folder.png

そこに,画像ファイルをドラッグ&ドロップして, #image("ファイルの名前")とすれば画像を挿入できます.

[動画]もあるよ. https://www.dropbox.com/scl/fi/ylnf0ulhdljnlatkn97d4/.mov?rlkey=5ej7uhd4rc9ma05yp30ovuffj&dl=0

画像を開いちゃって,元の画面に戻れないという人は main.typ というのをクリックしてください.

参照したい

見出し,図,式,脚注は「参照」できます.例えば次のようにしてみましょう.

#figure( 
image("folder.png")
,caption:[フォルダの図]
)<folder>

#figure(
table(columns: 2, [あ],[お]),
caption: []
)<50on>

$
integral_0^1 f(x)dif x
$<siki>

脚注を参照する.#footnote[参照される脚注]<footnote>

@folder と @50on と @siki と @footnote

これは数式番号や図表の番号が変わっても自動で更新されるので非常に便利です.
ただし,このままだと英語で日本語文書としてはイマイチなので参照をカスタマイズしてみましょう.詳しくは https://typst.app/docs/reference/model/ref/ をみていただくことにして,次のようにしてみます.

//図のラベルを置き換える
#show figure.where(kind:image): set figure(supplement: "図")
//表のラベルを置き換える
#show figure.where(kind:table): set figure(supplement: "表")
//その他の参照の設定
#show ref: it => {
  let eq = math.equation
  let el = it.element
  if el != none and el.func() == eq {
    // 数式の参照を書き換える.
    link(el.location())[
      #set text(fill:text.fill)
      #numbering(
      el.numbering,
      ..counter(eq).at(el.location())
    )]
  }
  else if el != none and el.func() == footnote {
    link(el.location())[
      //footnoteの参照を書き換える
      #set text(fill:text.fill)
      脚注#numbering(el.numbering,..counter(footnote).at(el.location()))]
  } else if el != none and el.func() == heading{
    //headingの参照を書き換える.
    link(el.location())[
      #set text(fill:text.fill)
      第#numbering(el.numbering,..counter(heading).at(el.location()))節]
  } else {it} 

ダウンロードしたい

右上端にある以下のボタンのうち, [↓] のようなボタンを押すとpdfがダウンロードできます.Backupでこのプロジェクトをバックアップします.

down.png

拡張機能を使いたい

typstは素の機能以外に,第3者が作ったパッケージという拡張機能を使うことができます.どのようなものがあるのかは以下のサイトを見てみてください.
https://typst.app/universe/

よく使われるものには以下のようなものがあります.詳しくはそれぞれの解説ページを見てください.

他人の作った機能を使いたい

世の中には親切な人がいて,便利機能を実装してくれる人がいます.もし公式のパッケージになっていれば,上のようにすれば良いのですが,そうでない場合には, 〜.typというファイルの形で流布している場合があります.その場合はそのファイルをフォルダーに入れ,以下のようにします.

#import "ファイル名.typ": * 

コードを書きたい

例えばpythonのコードを書くには次のようにします.
code.png

これは次のように表示されます1

n = 10
for i in range(n):
  i = i + 1
  print(i)

参考文献を書きたい

参考文献にはBiBTeXが利用できます.
詳細は公式の以下の解説を見てください.

https://typst.app/docs/reference/model/bibliography/
https://typst.app/docs/reference/model/cite/

BiBTeXを使わず直書きする場合は例えば以下の記事を参照してください.

設定がめんどいので楽したい

いろいろとテンプレートがありますので探してみましょう.私の自作は以下のリンクから利用できます.

https://typst.app/project/r3GVChhUil4_mwHCstXr6C: 日本語ドキュメント

https://typst.app/project/rvtZWoJrM--8T-FKkOl04Z: スライド

使い方は以下の通り:

  1. リンクをクリックしましょう
  2. < のようなボタンをクリックしましょう(下記の画像参照)
    back_button.png
  3. そうすると下記の画像のようなものが下に現れるので,マウスをそこに持っていって,□が二つ重なったボタンをクリックしましょう. share_button.png
  4. 最後に下記のメニューが出てくるので,Project nameを適当に設定し, Createボタンを押しましょう
    dup_menu.png

便利なサイトを知りたい

  1. 記号検索: https://detypify.quarticcat.com/
  2. 公式パッケージ・テンプレート: https://typst.app/universe

もっと知りたい

referenceを読みましょう. 新しい言語なので日本語の説明があまり見当たりません
https://typst.app/docs/reference/

  1. 構文の色付けや行番号などをつけるには[codly]https://typst.app/universe/package/codly というパッケージが有用です.

8
5
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
8
5