TOML 详解
TOML的由来
配置文件的使用由来已久,从.ini、XML、JSON、YAML再到TOML,语言的表达能力越来越强,同时书写便捷性也在不断提升。 TOML是前GitHub CEO, Tom Preston-Werner,于2013年创建的语言,其目标是成为一个小规模的易于使用的语义化配置文件格式。TOML被设计为可以无二义性的转换为一个哈希表(Hash table)。
例子
# 这是一个TOML文件
- title = "TOML Example"
- [owner]
- name = "Lance Uppercut"
- dob = 1979-05-27T07:32:00-08:00 # 日期是一等公民
- [database]
- server = "192.168.1.1"
- ports = [ 8001, 8001, 8002 ]
- connection_max = 5000
- enabled = true
- [servers]
- #你可以使用空格、制表符进行缩进,或者根本不缩进。TOML不关心缩进。
- [servers.alpha]
- ip = "10.0.0.1"
- dc = "eqdc10"
- [servers.beta]
- ip = "10.0.0.2"
- dc = "eqdc10"
- [clients]
- data = [ ["gamma", "delta"], [1, 2] ]
- # 数组内可以混入换行符
- hosts = [
- "alpha",
- "omega"
- ]
规范
- TOML是大小写敏感的
- TOML文件必须是UTF8编码的
- 空白符可以是制表符(0x09)或空格(0x20)
- 换行符可以是 LF (0x0A) 或 CRLF (0x0D0A)
TOML仍在不断完善,目前的版本0.4.0,下面是最新的规范。
注释
使用#来表示注释开始,至当前行尾结束。
- # I am a comment. Hear me roar. Roar.
- key = "value" # Yeah, you can do this.
字符串
TOML中有4种字符串表示方法:基本、多行-基本、字面量、多行-字面量。所有字符串必须是合法的UTF8字符。
基本字符串由双引号包裹,所有Unicode字符均可出现,除了双引号、反斜线、控制字符(U+0000 to U+001F)需要转义。
str = "I'm a string. \"You can quote me\". Name\tJos\u00E9\nLocation\tSF."
常用的转义序列:
- \b - backspace (U+0008)
- \t - tab (U+0009)
- \n - linefeed (U+000A)
- \f - form feed (U+000C)
- \r - carriage return (U+000D)
- \" - quote (U+0022)
- \\ - backslash (U+005C)
- \uXXXX - unicode (U+XXXX)
- \UXXXXXXXX - unicode (U+XXXXXXXX)
多行-基本字符串由三个双引号包裹,除了分隔符开始的换行外,字符串内的换行将被保留。
- str1 = """
- Roses are red
- Violets are blue"""
TOML解析器可以将其翻译为平台相关的字符串,如
- # Unix上,上述字符串等同于
- str2 = "Roses are red\nViolets are blue"
- # Windows上,上述字符串等同于
- str3 = "Roses are red\r\nViolets are blue"
在多行-基本字符串中可以在行尾使用\
来忽略其后的所有(换行符和空白符)直到第一个非空白符。
- # 以下字符串等价
- str1 = "The quick brown fox jumps over the lazy dog."
- str2 = """
- The quick brown \
- fox jumps over \
- the lazy dog."""
- key3 = """\
- The quick brown \
- fox jumps over \
- the lazy dog.\
- """
字面量字符串由单引号包裹,其内不允许转义,因此可以方便的表示基本字符串中需要转义的内容。
- # What you see is what you get.
- winpath = 'C:\Users\nodejs\templates'
- winpath2 = '\\ServerX\admin$\system32\'
- quoted = 'Tom "Dubs" Preston-Werner'
- regex = '<\i\c*\s*>'
多行-字面量字符串与多行-基本字符串类似。
整数
- int1 = +99
- int2 = 42
- int3 = 0
- int4 = -17
为了增加可读性,整数可以使用_
分隔。每个_
必须被至少一个数字环绕。
不被允许的表达:前置0,2、8、16进制、无穷、NaN。 整数的范围是64bit signed long类型的范围。
浮点数
- # fractional
- flt1 = +1.0
- flt2 = 3.1415
- flt3 = -0.01
- # exponent
- flt4 = 5e+22
- flt5 = 1e6
- flt6 = -2E-2
- # both
- flt7 = 6.626e-34
浮点数的范围是64 bit double类型的范围。
布尔值
小写的true或false。
- bool1 = true
- bool2 = false
日期时间
使用RFC 3339描述的时间格式
- date1 = 1979-05-27T07:32:00Z
- date2 = 1979-05-27T00:32:00-07:00
- date3 = 1979-05-27T00:32:00.999999-07:00
数组
数组使用方括号包裹。空格会被忽略,包括换行符。元素使用逗号分隔。注意,不允许混用数据类型(所有的字符串类型均为同一类型)。
- arr1 = [ 1, 2, 3 ]
- arr2 = [ "red", "yellow", "green" ]
- arr3 = [ [ 1, 2 ], [3, 4, 5] ]
- arr4 = [ "all", 'strings', """are the same""", '''type'''] # this is ok
- arr5 = [ [ 1, 2 ], ["a", "b", "c"] ] # this is ok
- arr6 = [ 1, 2.0 ] # note: this is NOT ok
表格
表格叶称为哈希表或字典,用来存储键值对。表格名由方括号包裹,且自成一行。
- [table]
表格名下,直到下一个表格名或文件尾,均为当前表格的内容。
- [table]
- key = "value"
- bare_key = "value"
- bare-key = "value"
- "127.0.0.1" = "value"
- "character encoding" = "value"
- "ʎǝʞ" = "value"
表格可以嵌套,即表格中某个键的值可以为表格。
- [dog]
- onekey = onevalue
- [dog.tater]
- type = "pug"
等价于
- {
- "dog": {
- "onekey":"onevalue",
- "tater": { "type": "pug" }
- }
- }
如果你不想的话,你不用声明所有的父表。TOML 知道该如何处理。
- # [x] 你
- # [x.y] 不需要
- # [x.y.z] 这些
- [x.y.z.w] # 可以直接写
表格数组
- [[products]]
- name = "Hammer"
- sku = 738594937
- [[products]]
- [[products]]
- name = "Nail"
- sku = 284758393
- color = "gray"
等价于以下的 JSON 结构:
- {
- "products": [
- { "name": "Hammer", "sku": 738594937 },
- { },
- { "name": "Nail", "sku": 284758393, "color": "gray" }
- ]
- }
目前支持几乎我熟知所有语言,对应的列表也请查看上面 github 地址,会有具体项目支持。
TOML 详解的更多相关文章
- 以太坊客户端Geth命令用法-参数详解
Geth在以太坊智能合约开发中最常用的工具(必备开发工具),一个多用途的命令行工具. 熟悉Geth可以让我们有更好的效率,大家可收藏起来作为Geth命令用法手册. 本文主要是对geth help的翻译 ...
- ansible中常用模块详解
ansible中常用的模块详解: file模块 ansible内置的可以查看模块用法的命令如下: [root@docker5 ~]# ansible-doc -s file - name: Sets ...
- 【转】gitlab CI流水线配置文件.gitlab-ci.yml详解
目录 GitLab CI流水线配置文件.gitlab-ci.yml详解 实验环境 GitLab CI介绍 .gitlab-ci.yml 配置参数 参数详解 script image services ...
- Python - poetry(3)配置项详解
config 命令 poetry 通过 config 命令进行配置 也可以直接在 config.toml 文件中进行配置,该文件将在首次运行该命令时自动创建 文件目录 macOS:~/Library/ ...
- Linq之旅:Linq入门详解(Linq to Objects)
示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...
- 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)
一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...
- EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解
前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...
- Java 字符串格式化详解
Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...
- Android Notification 详解(一)——基本操作
Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...
随机推荐
- C++ 函数 引用
一.引用的概念 引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样.引用的声明方法: 类型标识符 &引用名 = 目标变量名: 为一个变量起一个别名.假如有一个变量a,想给 ...
- Daily Srum 10.28
这两天我们和其他两组进行了一次会议,主要讨论的是用什么框架来搭建这个平台.在线系统的那一组希望我们用nutch.solr.hbase这一套工具,这对于我们两组来说是一次挑战,毕竟我们一开始用的是关系型 ...
- jQuery全屏滚动插件fullPage使用
1. 引入jquery.js和jquery.fullPage.min.js <script src="jquery.min.js"></script> &l ...
- Leetcode题库——14.最长公共前缀
@author: ZZQ @software: PyCharm @file: longestCommonPrefix.py @time: 2018/9/16 17:50 要求:查找字符串数组中的最长公 ...
- android--实现通过点击链接打开apk(应用图标在桌面消失)
首先在AndroidManifest.xml的MAIN Activity下追加以下内容.(启动Activity时给予) ※必须添加项 <intent-filter> <action ...
- HttpContext.Current.Server.MapPath("/") 未将对象设置到对象的实例异常。
多线程中的System.Web.HttpContext.Current.Server.MapPath("/") 多线程中Server.MapPath会失效... 网上找到几种解决方 ...
- VNC Server (Ubuntu 16.04.3 GNOME)
1. 安装VNC服务 sudo apt-get install vnc4server -y 2. 启动VNC服务 vncserver :1 3. 此时客户端连上后你会发现灰屏,原因出在~/.vnc/x ...
- C++中sizeof操作符与strlen函数
sizeof操作符: sizeof是一个操作符,返回一条表达式或一个类型名字所占的字节数.返回值一个常量表达式,类型为size_t. size_t sizeof(type) size_t sizeof ...
- 题解 P3870 【[TJOI2009]开关】
这个题我愣是交了好几遍没有过...... 后来@_皎月半洒花dalao告诉我说要^儿子节点的tag,然后就明白了...... 行吧,先上题面: 题目描述 现有N(2 ≤ N ≤ 100000)盏灯排成 ...
- Mac突然连不上WiFi
标签(空格分隔): 杂七杂八的问题 从昨晚开始,Mac突然连不上WiFi了,人又在图书馆,上不了网好焦急.于是搜了很多方法,也不知是哪个起作用了,反正现在可以了. 步骤一 打开"Finder ...