mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2025-01-14 21:25:58 +00:00
191 lines
7.2 KiB
Markdown
191 lines
7.2 KiB
Markdown
---
|
||
contributors:
|
||
- [Leigh Brenecki, 'https://leigh.net.au']
|
||
- [Suhas SG, 'https://github.com/jargnar']
|
||
translators:
|
||
- [haru, 'https://haru52.com/']
|
||
---
|
||
|
||
YAMLはデータのシリアライズ用言語で、
|
||
人間が直接読み書きしやすいようにデザインされています。
|
||
|
||
YAMLはJSONの厳格なスーパーセットで、
|
||
改行とインデントが構文的に意味を持つというPythonに似た仕様を追加しています。
|
||
しかしPythonとは異なりYAMLではインデントにタブ文字を使うことはできません。
|
||
|
||
```yaml
|
||
--- # ドキュメント開始
|
||
|
||
# YAMLのコメントはこんな感じです。
|
||
|
||
##############
|
||
# スカラー型 #
|
||
##############
|
||
|
||
# (ドキュメント全体を含む)ルートオブジェクトはマップになります。
|
||
# これは他言語における辞書型、ハッシュ、オブジェクトなどと等価です。
|
||
キー: 値
|
||
別のキー: 別の値。
|
||
数値: 100
|
||
指数表記: 1e+12
|
||
# 1 はbooleanでなく数値として解釈されます。
|
||
# もしbooleanとして解釈してほしい場合はtrueを使います
|
||
boolean: true
|
||
null値: null
|
||
スペースを 含む キー: 値
|
||
# 文字列をクォートで囲う必要がないことに注意してください。
|
||
# しかし囲うこともできます。
|
||
しかし: 'クォートで囲まれた文字列。'
|
||
'キーもクォートで囲えます。': "keyの中で ':' を使いたいときに有用です。"
|
||
シングルクォート: 'には ''1つの'' エスケープパターンがあります'
|
||
ダブルクォート: "には多くのエスケープパターンがあります:\", \0, \t, \u263A,
|
||
\x0d\x0a == \r\n, など、他にもあります。"
|
||
# UTF-8/16/32文字はエンコードされている必要があります
|
||
上付き2: \u00B2
|
||
|
||
# 複数行の文字列は(| を使う)「リテラルブロック」、
|
||
# または、('>' を使う)「折り畳みブロック」として書くことができます
|
||
リテラルブロック: |
|
||
この文章のブロック全体が「リテラルブロック」キーの値になり、
|
||
改行は保持されます。
|
||
|
||
リテラルはインデントを解除するまで続き、先頭行のインデント文字数分を
|
||
各行のテキストの先頭から取り除きます。
|
||
|
||
「よりインデントの深い」行はその分のインデントを保持します -
|
||
この2行はスペース4個分インデントされます。
|
||
折り畳みスタイル: >
|
||
この文章のブロック全体が「折り畳みスタイル」の値になります。
|
||
しかしこちらの場合、全ての改行がスペース1個に置き換わります。
|
||
|
||
直前のような空行は改行文字に変換されます。
|
||
|
||
「よりインデントの深い」行も改行を保持します -
|
||
このテキストは2行にわたって表示されます。
|
||
|
||
##################
|
||
# コレクション型 #
|
||
##################
|
||
|
||
# 入れ子を表現するにはインデントを使います。
|
||
# スペース2個のインデントが好まれます(が必須ではありません)。
|
||
入れ子のマップ:
|
||
キー: 値
|
||
別のキー: 別の値
|
||
別の入れ子のマップ:
|
||
こんにちは: こんにちは
|
||
|
||
# マップのキーは文字列である必要はありません。
|
||
0.25: 小数のキー
|
||
|
||
# 複数行オブジェクトのような複雑なキーも使用可能です。
|
||
# ? の後にスペースを入れることで複雑なキーの開始を宣言できます。
|
||
? |
|
||
これはキーです
|
||
複数行あります
|
||
: そしてこれがその値です
|
||
|
||
# YAMLではシーケンスを複雑なキー構文で使うこともできます
|
||
# しかし、言語パーサーによってはエラーになるかもしれません
|
||
# 例
|
||
? - マンチェスター・ユナイテッド
|
||
- レアル・マドリード
|
||
: [2001-01-01, 2002-02-02]
|
||
|
||
# シーケンス(リストや配列と等価)はこんな感じです
|
||
# ('-' はインデントとしてカウントしてください):
|
||
シーケンス:
|
||
- アイテム1
|
||
- アイテム2
|
||
- 0.5 # シーケンスには異なる型の値を混在させられます
|
||
- アイテム4
|
||
- キー: 値
|
||
別のキー: 別の値
|
||
-
|
||
- これはシーケンスです
|
||
- 別のシーケンス内部
|
||
- - - 入れ子のシーケンス表記は
|
||
- 折り畳めます
|
||
|
||
# YAMLはJSONのスーパーセットなので、
|
||
# JSON形式のマップとシーケンスを書くこともできます:
|
||
jsonマップ: {"キー": "値"}
|
||
jsonシーケンス: [3, 2, 1, "発進"]
|
||
クォートは任意: {キー: [3, 2, 1, 発進]}
|
||
|
||
######################
|
||
# その他のYAMLの機能 #
|
||
######################
|
||
|
||
# YAMLには「アンカー」と呼ばれる便利な機能もあります。これによりコンテンツを
|
||
# ドキュメント内で簡単に複製できます。これらのキーはどちらも同じ値を持ちます:
|
||
アンカーされたコンテンツ: &anchor_name この文字列は2つのキーの値になります。
|
||
他のアンカー: *anchor_name
|
||
|
||
# アンカーは複製/継承プロパティとして使えます
|
||
ベース: &base
|
||
名前: みんな同じ名前を持ちます
|
||
|
||
# 記号 << はマージキー言語非依存型(Merge Key Language-Independent Type)
|
||
# と呼ばれます。これは指定された1つ以上のマップの全てのキーを現在のマップに
|
||
# 挿入することを示すために使われます。
|
||
|
||
foo:
|
||
<<: *base
|
||
年齢: 10
|
||
|
||
bar:
|
||
<<: *base
|
||
年齢: 20
|
||
|
||
# fooとbarも「名前: みんな同じ名前を持ちます」を持ちます
|
||
|
||
# YAMLにはタグもあり、明示的に型を宣言できます。
|
||
明示的な文字列: !!str 0.5
|
||
# 言語特有のタグを実装したパーサーもあり、例えばPythonの複素数型が使えます。
|
||
pythonの複素数型: !!python/complex 1+2j
|
||
|
||
# YAMLの複雑なキーでは言語特有のタグも使えます
|
||
? !!python/tuple [5, 7]
|
||
: 五十七
|
||
# Python上で {(5, 7): '五十七'} として扱われます
|
||
|
||
####################
|
||
# その他のYAMLの型 #
|
||
####################
|
||
|
||
# 文字列と数値がYAMLの理解できる唯一のスカラーではありません。
|
||
# ISO形式の日付や日時リテラルもパースされます。
|
||
日時: 2001-12-15T02:59:43.1Z
|
||
スペースを含む日時: 2001-12-14 21:59:43.10 -5
|
||
日付: 2002-12-14
|
||
|
||
# !!binaryタグは文字列の実体がバイナリblobのbase64エンコード表現であることを
|
||
# 示します。
|
||
gifファイル: !!binary |
|
||
R0lGODlhDAAMAIQAAP//9/X17unp5WZmZgAAAOfn515eXvPz7Y6OjuDg4J+fn5
|
||
OTk6enp56enmlpaWNjY6Ojo4SEhP/++f/++f/++f/++f/++f/++f/++f/++f/+
|
||
+f/++f/++f/++f/++f/++SH+Dk1hZGUgd2l0aCBHSU1QACwAAAAADAAMAAAFLC
|
||
AgjoEwnuNAFOhpEMTRiggcz4BNJHrv/zCFcLiwMWYNG84BwwEeECcgggoBADs=
|
||
|
||
# YAMLにはセット型もあり、それはこんな感じです:
|
||
セット:
|
||
? アイテム1
|
||
? アイテム2
|
||
? アイテム3
|
||
または: {アイテム1, アイテム2, アイテム3}
|
||
|
||
# セットは値がnullのただのマップで、直前のセットは以下と等価です:
|
||
セット2:
|
||
アイテム1: null
|
||
アイテム2: null
|
||
アイテム3: null
|
||
|
||
... # ドキュメント終了
|
||
```
|
||
|
||
### 補足資料
|
||
|
||
+ [YAML公式ウェブサイト](https://yaml.org/)
|
||
+ [オンラインYAMLバリデーター](http://www.yamllint.com/)
|