Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/json-next/awesome-json-next
A Collection of What's Next for Awesome JSON (JavaScript Object Notation) for Structured (Meta) Data in Text - JSON5, HJSON, HanSON, TJSON, SON, CSON, USON, JSONX/JSON11 & Many More
https://github.com/json-next/awesome-json-next
List: awesome-json-next
cson data hanson hcl hjson hocon json json5 jsonlines metadata ndjson opendata son txt ucl uson
Last synced: 3 months ago
JSON representation
A Collection of What's Next for Awesome JSON (JavaScript Object Notation) for Structured (Meta) Data in Text - JSON5, HJSON, HanSON, TJSON, SON, CSON, USON, JSONX/JSON11 & Many More
- Host: GitHub
- URL: https://github.com/json-next/awesome-json-next
- Owner: json-next
- License: cc0-1.0
- Created: 2017-06-28T22:53:13.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-02-23T18:03:04.000Z (almost 4 years ago)
- Last Synced: 2024-05-19T21:01:49.234Z (8 months ago)
- Topics: cson, data, hanson, hcl, hjson, hocon, json, json5, jsonlines, metadata, ndjson, opendata, son, txt, ucl, uson
- Homepage:
- Size: 56.6 KB
- Stars: 58
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- fucking-lists - awesome-json-next
- awesome-starred - json-next/awesome-json-next - A Collection of What's Next for Awesome JSON (JavaScript Object Notation) for Structured (Meta) Data in Text - JSON5, HJSON, HanSON, TJSON, SON, CSON, USON, JSONX/JSON11 & Many More (json)
- lists - awesome-json-next
- ultimate-awesome - awesome-json-next - A Collection of What's Next for Awesome JSON (JavaScript Object Notation) for Structured (Meta) Data in Text - JSON5, HJSON, HanSON, TJSON, SON, CSON, USON, JSONX/JSON11 & Many More. (Other Lists / Monkey C Lists)
README
JSON5 • HJSON • HanSON • SON • TJSON • CSON • USON • JSONX • JSON11 • JSON XI • JSONII •
JSON Lines • NDJSON •
HOCON • HCL • UCL# Awesome JSON - What's Next?
A Collection of What's Next for Awesome JSON (JavaScript Object Notation) for structured (meta) data in text.
#### _Contributions welcome. Anything missing? Send in a pull request. Thanks._
## What's Missing in JSON?
1. Comments, Comments, Comments
2. Unquoted Keys
3. Multi-Line Strings
- a) Folded -- Folds Newlines
- b) Unfolded
4. Trailing Commas in Arrays and ObjectsMore:
- Date/DateTime/Timestamp Type
- Optional Commas
- Optional Unquoted String Values
- "Raw" String (e.g. `''` instead of `""`)
- No need to escape `\` or `"` etc. To escape `'` use `'''` e.g. `''''Henry's Themes'''`
- More Data Types (`set`, `map`, `symbol`, etc.)
- And much more## Discussion
_Fixing JSON - Comments, Please!_
> We can easily agree on what’s wrong with JSON, and I can't help wondering if it'd be worth fixing it.
>
> -- Tim Bray ([Fixing JSON](https://www.tbray.org/ongoing/When/201x/2016/08/20/Fixing-JSON))> XML already does everything JSON does! And there's no way to differentiate between nodes and attributes!
> And there are no namespaces! And no schemas! What's the point of JSON?
>
> -- Anonymous> We need to fix engineers that try to 'fix JSON', absolutely nothing is broken with JSON.
>
> -- Anonymous- [Fixing JSON](https://www.tbray.org/ongoing/When/201x/2016/08/20/Fixing-JSON) by Tim Bray, Aug 2016
- Major Irritant: Commas • Irritant: Timestamps • Major irritant: Schemas
- [The Fixing-JSON Conversation](https://www.tbray.org/ongoing/When/201x/2016/08/22/Fixing-JSON-Redux) by Tim Bray, Aug 2016
- Just use X • Comments, please please comments! • You shouldn't want to hand-edit JSON •
You'll lose JavaScript compatibility! • Unquoted field names, please! • Is it too late?
- [Fixing JSON Comments @ Hacker News](https://news.ycombinator.com/item?id=12327668), Aug 2016## What's Next?
[JSON5](#json5) •
[HJSON](#hjson) •
[HanSON](#hanson) •
[SON](#son) •
[JSONX](#jsonx) •
[CSON](#cson) •
[USON](#uson)### JSON5
_Modern JSON - JSON for the ES5 Era_
web: [json5.org](http://json5.org),
github: [json5](https://github.com/json5)JSON for "Humans" (not Machines). Adds:
- Comments- Allow both inline (single-line) and block (multi-line) comments are allowed (like ES5)
- Keys can be unquoted if they're valid identifiers e.g. a-z0-9 (like ES5)
- Single and double quoted strings (like ES5)
- Allows multi-line string with backslash (like ES5)
- Allow trailing commas for arrays and objects.
- And some more.```
// This file is written in JSON5 syntax, naturally, but npm needs a regular
// JSON file, so compile via `npm run build`. Be sure to keep both in sync!{
name: 'json5',
version: '0.5.0',
description: 'JSON for the ES5 era.',
keywords: ['json', 'es5'],
author: 'Aseem Kishore ',
contributors: [
// TODO: Should we remove this section in favor of GitHub's list?
// https://github.com/json5/json5/contributors
'Max Nanasy ',
'Andrew Eisenberg ',
'Jordan Tucker ',
],
main: 'lib/json5.js',
bin: 'lib/cli.js',
files: ["lib/"],
dependencies: {},
devDependencies: {
gulp: "^3.9.1",
'gulp-jshint': "^2.0.0",
jshint: "^2.9.1",
'jshint-stylish': "^2.1.0",
mocha: "^2.4.5"
},
scripts: {
build: 'node ./lib/cli.js -c package.json5',
test: 'mocha --ui exports --reporter spec',
// TODO: Would it be better to define these in a mocha.opts file?
},
homepage: 'http://json5.org/',
license: 'MIT',
repository: {
type: 'git',
url: 'https://github.com/json5/json5',
},
}
```### HJSON
_A "Human" User Interface for JSON_
web: [hjson.org](http://hjson.org),
github: [hjson](https://github.com/hjson)- Commas Optional
- Add comments, hash-style (#), line-style (//) and block-style (/* */)
- Allow Keys without quotes
- Allow Strings without quotes
- Allow Multi-line strings Python-style e.g. ''' text '''```
{
// use #, // or /**/ comments,
// omit quotes for keys
key: 1
// omit quotes for strings
contains: everything on this line
// omit commas at the end of a line
cool: {
foo: 1
bar: 2
}
// allow trailing commas
list: [
1,
2,
]
// and use multiline strings
realist:
'''
My half empty glass,
I will fill your empty half.
Now you are half full.
'''
}
```### HanSON
_JSON for Humans_
github: [timjansen/hanson](https://github.com/timjansen/hanson)
Adds:
- HanSON is JSON with comments, multi-line strings and unquoted property names.
- Comments use JavaScript syntax (`//`, `/**/`).
- Supports backticks as quotes (\`\`) for multi-line strings.
- You can use either double-quotes (`""`) or single-quotes (`''`) for single-line strings.
- Property names do not require quotes if they are valid JavaScript identifiers.
- Commas after the last list element or property will be ignored.
- Every JSON string is valid HanSON.
- HanSON can easily be converted to real JSON.```js
{
listName: "Sesame Street Monsters", // note that listName needs no quotes
content: [
{
name: "Cookie Monster",
/* Note the template quotes and unescaped regular quotes in the next string */
background: `Cookie Monster used to be a
monster that ate everything, especially cookies.
These days he is forced to eat "healthy" food.`
}, {
// You can single-quote strings too:
name: 'Herry Monster',
background: `Herry Monster is a furry blue monster with a purple nose.
He's mostly retired today.`
}, // don't worry, the trailing comma will be ignored
]
}
```### SON
_Simple Object Notation_
github: [aleksandergurin/simple-object-notation](https://github.com/aleksandergurin/simple-object-notation)
Adds:
- comments starts with # sign and ends with newline (\n)
- comma after a key-value pair is optional
- comma after an array element is optional```
{
# Personal information
"name": "Alexander Grothendieck"
"fields": "mathematics"
"main_topics": [
"Etale cohomology"
"Motives"
"Topos theory"
"Schemes"
]
}
```### JSONX
_JSON with Extensions (JSONX) or JSON v1.1 (a.k.a. JSON11 or JSON XI or JSON II) - JSON Evolved for Humans - Easy-to-Write, Easy-to-Read_
github: [json-next](https://github.com/json-next)
JSON v1.1 includes all JSON extensions from HanSON (JSON for Humans):
- quotes for strings are optional if they follow JavaScript identifier rules.
- you can alternatively use backticks, as in ES6's template string literal, as quotes for strings.
A backtick-quoted string may span several lines and you are not required to escape regular quote characters,
only backticks. Backslashes still need to be escaped, and all other backslash-escape sequences work like in
regular JSON.
- for single-line strings, single quotes (`''`) are supported in addition to double quotes (`""`)
- you can use JavaScript comments, both single line (`//`) and multi-line comments (`/* */`), in all places where JSON allows whitespace.
- Commas after the last list element or object property will be ignored.Plus all JSON extensions from SON (Simple Object Notation):
- comments starts with `#` sign and ends with newline (`\n`)
- comma after an object key-value pair is optional
- comma after an array item is optionalExample:
```
{
# use shell-like commentslistName: "Sesame Street Monsters" # note: comments after key-value pairs are optional
content: [
{
name: "Cookie Monster"
// note: the template quotes and unescaped regular quotes in the next string
background: `Cookie Monster used to be a
monster that ate everything, especially cookies.
These days he is forced to eat "healthy" food.`
}, {
// You can single-quote strings too:
name: 'Herry Monster',
background: `Herry Monster is a furry blue monster with a purple nose.
He's mostly retired today.`
}, /* don't worry, the trailing comma will be ignored */
]
}
```### CSON (I)
_Cursive Script Object Notation (CSON). A strict superset of JavaScript Object Notation (JSON) that can be written by hand (hence the name) and translated to a canonical JSON_
github: [lifthrasiir/cson](https://github.com/lifthrasiir/cson) - designed by Kang Seonghoon
CSON:
```
# CSON data example
hello =
|world
| ...and goodbye
the = ['answer', 'is'
42]
```same as:
``` javascript
{
"hello": "world\n ...and goodbye",
"the": ["answer", "is",
42]
}
```### CSON (II)
_CoffeeScript-Object-Notation. Same as JSON but for CoffeeScript objects_
github: [bevry/cson](https://github.com/bevry/cson)
CSON:
``` coffeescript
# Comments!!!# An Array with no commas!
greatDocumentaries: [
'earthlings.com'
'forksoverknives.com'
'cowspiracy.com'
]# An Object without braces!
importantFacts:
# Multi-Line Strings! Without Quote Escaping!
emissions: '''
Livestock and their byproducts account for at least 32,000 million tons of carbon dioxide (CO2) per year, or 51% of all worldwide greenhouse gas emissions.
Goodland, R Anhang, J. “Livestock and Climate Change: What if the key actors in climate change were pigs, chickens and cows?”
WorldWatch, November/December 2009. Worldwatch Institute, Washington, DC, USA. Pp. 10–19.
http://www.worldwatch.org/node/6294
'''landuse: '''
Livestock covers 45% of the earth’s total land.
Thornton, Phillip, Mario Herrero, and Polly Ericksen. “Livestock and Climate Change.” Livestock Exchange, no. 3 (2011).
https://cgspace.cgiar.org/bitstream/handle/10568/10601/IssueBrief3.pdf
'''burger: '''
One hamburger requires 660 gallons of water to produce – the equivalent of 2 months’ worth of showers.
Catanese, Christina. “Virtual Water, Real Impacts.” Greenversations: Official Blog of the U.S. EPA. 2012.
http://blog.epa.gov/healthywaters/2012/03/virtual-water-real-impacts-world-water-day-2012/
“50 Ways to Save Your River.” Friends of the River.
http://www.friendsoftheriver.org/site/PageServer?pagename=50ways
'''milk: '''
1,000 gallons of water are required to produce 1 gallon of milk.
“Water trivia facts.” United States Environmental Protection Agency.
http://water.epa.gov/learn/kids/drinkingwater/water_trivia_facts.cfm#_edn11
'''more: 'http://cowspiracy.com/facts'
```same as:
``` javascript
{
"greatDocumentaries": [
"earthlings.com",
"forksoverknives.com",
"cowspiracy.com"
],
"importantFacts": {
"emissions": "Livestock and their byproducts account for at least 32,000 million tons of carbon dioxide (CO2) per year, or 51% of all worldwide greenhouse gas emissions.\nGoodland, R Anhang, J. “Livestock and Climate Change: What if the key actors in climate change were pigs, chickens and cows?”\nWorldWatch, November/December 2009. Worldwatch Institute, Washington, DC, USA. Pp. 10–19.\nhttp://www.worldwatch.org/node/6294",
"landuse": "Livestock covers 45% of the earth’s total land.\nThornton, Phillip, Mario Herrero, and Polly Ericksen. “Livestock and Climate Change.” Livestock Exchange, no. 3 (2011).\nhttps://cgspace.cgiar.org/bitstream/handle/10568/10601/IssueBrief3.pdf",
"burger": "One hamburger requires 660 gallons of water to produce – the equivalent of 2 months’ worth of showers.\nCatanese, Christina. “Virtual Water, Real Impacts.” Greenversations: Official Blog of the U.S. EPA. 2012.\nhttp://blog.epa.gov/healthywaters/2012/03/virtual-water-real-impacts-world-water-day-2012/\n“50 Ways to Save Your River.” Friends of the River.\nhttp://www.friendsoftheriver.org/site/PageServer?pagename=50ways",
"milk": "1,000 gallons of water are required to produce 1 gallon of milk.\n“Water trivia facts.” United States Environmental Protection Agency.\nhttp://water.epa.gov/learn/kids/drinkingwater/water_trivia_facts.cfm#_edn11",
"more": "http://cowspiracy.com/facts"
}
}
```### USON
_μson - A compact human-readable data serialization format specially designed for shell_
github: [burningtree/uson](https://github.com/burningtree/uson)
Principles:
- Superset of JSON (every JSON is valid μson).
- Whitespace is not significant.
- String quoting `"` is optional.
- In Array or Object, comma `,` can be replaced by whitespace ` `.
- Assignation with colon `:` can be repeated to create nested objects.
- You can use own types, casting is done by `!` character.USON:
```
number:12.05 text:Banana quotedText:"John Devilseed" empty:null good:true
```same as:
```json
{
"number": 12.05,
"text": "Banana",
"quotedText": "John Devilseed",
"empty": null,
"good": true
}
```USON:
```
simple:[1 2 3] texts:[Malta Budapest "New York"] objects:[{id:1}]
```same as:
```json
{
"simple": [
1,
2,
3
],
"texts": [
"Malta",
"Budapest",
"New York"
],
"objects": [
{
"id": 1
}
]
}
```## JSON with (Rich) Types
### TJSON
_Tagged JSON with Rich Type Annotations_
web: [tjson.org](https://www.tjson.org), github: [tjson](https://github.com/tjson)
A tagging scheme/microformat for enriching the types stored in self-describing, schema-free JSON documents.
Why? Enables "content-aware hashing" where different encodings of the same data (including both TJSON and binary formats like Protocol Buffers, MessagePack, BSON, etc) share the same content hash and therefore the same cryptographic signature.
TJSON supports the following data types:
- Objects (O): Name/value dictionaries. The names of objects in TJSON carry a postfix "tag" which acts as a type annotation for the associated value.
- Arrays (A): Lists of values: identical to JSON, but typed by their containing objects. Unlike JSON, arrays cannot be used as a top-level expression: only objects are allowed.
- Sets (S): Lists of unique values: similar to an array, but repeated elements are disallowed.
- Strings (s): TJSON strings are Unicode and always serialized as UTF-8. When used as the name of a member of an object, they carry a mandatory "tag" which functions as a self-describing type annotation which provides a type signature for the associated value.
- Binary Data (d, d16, d32, d64): First-class support for 8-bit clean binary data, encoded in a variety of formats including hexadecimal (a.k.a. base16), base32, and base64url.
- Numbers:
- Integers (i,u): TJSON supports the full ranges of both signed and unsigned 64-bit integers by serializing them as strings.
- Floating points (f): Floating point numbers in TJSON are identical to JSON, but can always be disambiguated from integers.
- Timestamps (t): TJSON has a first-class type for representing date/time timestamp values, serialized as a subset of RFC 3339 (an ISO 8601-alike).
- Boolean Values (b): TJSON supports the true and false values from JSON (null is expressly disallowed).Examples:
``` json
{
"array-example:A": [
{
"string-example:s": "Hello, world!",
"binary-data-example:d": "QklOQVJZ",
"float-example:f": 0.42,
"int-example:i": "42",
"timestamp-example:t": "2020-11-06T22:27:34Z",
"boolean-example:b": true
}
],
"set-example:S": [1, 2, 3]
}
```## JSON is the New CSV - JSON Formats for Line-Oriented Tables / Records
_One Line, One Data Record_
[JSON Lines](#json-lines) •
[NDJSON ](#ndjson)### JSON Lines
web: [jsonlines.org](http://jsonlines.org)
One Line, One Record - Newline (nl or \n) Separated
```
["Name", "Session", "Score", "Completed"]
["Gilbert", "2013", 24, true]
["Alexa", "2013", 29, true]
["May", "2012B", 14, false]
["Deloise", "2012A", 19, true]
```Pros:
- Supports JSON Datatypes (Numbers, Bool, Null, etc.)
or nested data records e.g.
```
{"name": "Gilbert", "wins": [["straight", "7♣"], ["one pair", "10♥"]]}
{"name": "Alexa", "wins": [["two pair", "4♠"], ["two pair", "9♠"]]}
{"name": "May", "wins": []}
{"name": "Deloise", "wins": [["three of a kind", "5♣"]]}
```### NDJSON
_Newline Delmited JSON_
web: [ndjson.org](http://ndjson.org),
github: [ndjson](https://github.com/ndjson)1. Line Separator is '\n'
2. Each Line is a valid JSON Value```
{"some":"thing"}
{"foo":17,"bar":false,"quux":true}
{"may":{"include":"nested","objects":["and","arrays"]}}
```(Source: [specs.okfnlabs.org/ndjson](http://specs.okfnlabs.org/ndjson))
## More Formats
_: = {} []_
### HOCON
_Human-Optimized Config Object Notation_
github: [typesafehub/config/HOCON](https://github.com/typesafehub/config/blob/master/HOCON.md)
### HCL
_HashiCorp Configuration Language_
github: [hashicorp/hcl](https://github.com/hashicorp/hcl)
### UCL
_Universal Configuration Language_
github: [vstakhov/libucl](https://github.com/vstakhov/libucl)
### AXON
_AXON is eXtended Object Notation_
web: [intellimath.bitbucket.io/axon](https://intellimath.bitbucket.io/axon/)
### Objective Markup Notation - {mark}
_Objective Markup Notation, abbreviated as Mark or {mark} - a unified notation for both object and markup data_
web: [mark.js.org](https://mark.js.org), github: [henry-luo/mark](https://github.com/henry-luo/mark)
### And More
See [Format Extensions](https://github.com/burningtree/awesome-json#format-extensions),
[Supersets](https://github.com/burningtree/awesome-json#supersets) and
[Related Formats](https://github.com/burningtree/awesome-json#related-formats)
in [Awesome JSON (@burningtree)](https://github.com/burningtree/awesome-json)## Articles
- [JSON: The Fat-Free Alternative to XML](http://www.json.org/xml) by Douglas Crockford
- [Parsing JSON is a Minefield](http://seriot.ch/parsing_json.php) by Nicolas Seriot## Meta
**License**
![](https://publicdomainworks.github.io/buttons/zero88x31.png)
The awesome list is dedicated to the public domain. Use it as you please with no restrictions whatsoever.
**Questions? Comments?**
Post them to the [wwwmake forum](http://groups.google.com/group/wwwmake). Thanks!