blob: 5542ce48c38023df6f9186fd617861931b8156ff [file] [log] [blame]
Christian Heimes90540002008-05-08 14:29:10 +00001r"""Command-line tool to validate and pretty-print JSON
2
3Usage::
4
Benjamin Petersonc6b607d2009-05-02 12:36:44 +00005 $ echo '{"json":"obj"}' | python -m json.tool
Christian Heimes90540002008-05-08 14:29:10 +00006 {
7 "json": "obj"
8 }
Benjamin Petersonc6b607d2009-05-02 12:36:44 +00009 $ echo '{ 1.2:3.4}' | python -m json.tool
Serhiy Storchakac510a042013-02-21 20:19:16 +020010 Expecting property name enclosed in double quotes: line 1 column 3 (char 2)
Christian Heimes90540002008-05-08 14:29:10 +000011
12"""
Benjamin Peterson940e2072014-03-21 23:17:29 -050013import argparse
Christian Heimes90540002008-05-08 14:29:10 +000014import json
Benjamin Peterson940e2072014-03-21 23:17:29 -050015import sys
16
Christian Heimes90540002008-05-08 14:29:10 +000017
18def main():
Benjamin Peterson940e2072014-03-21 23:17:29 -050019 prog = 'python -m json.tool'
20 description = ('A simple command line interface for json module '
21 'to validate and pretty-print JSON objects.')
22 parser = argparse.ArgumentParser(prog=prog, description=description)
Inada Naoki808769f2019-12-04 18:39:31 +090023 parser.add_argument('infile', nargs='?',
24 type=argparse.FileType(encoding="utf-8"),
Hervé Beraud4d45a3b2019-05-14 18:52:42 +020025 help='a JSON file to be validated or pretty-printed',
26 default=sys.stdin)
Inada Naoki808769f2019-12-04 18:39:31 +090027 parser.add_argument('outfile', nargs='?',
28 type=argparse.FileType('w', encoding="utf-8"),
Hervé Beraud4d45a3b2019-05-14 18:52:42 +020029 help='write the output of infile to outfile',
30 default=sys.stdout)
Berker Peksag39e4c4d2014-11-10 09:56:54 +020031 parser.add_argument('--sort-keys', action='store_true', default=False,
32 help='sort the output of dictionaries alphabetically by key')
wim glennefefe252019-12-06 00:44:01 -060033 parser.add_argument('--no-ensure-ascii', dest='ensure_ascii', action='store_false',
34 help='disable escaping of non-ASCII characters')
HongWeipengf1944792018-11-07 18:09:32 +080035 parser.add_argument('--json-lines', action='store_true', default=False,
36 help='parse input using the jsonlines format')
Daniel Himmelstein03257942019-12-04 01:15:19 -050037 group = parser.add_mutually_exclusive_group()
38 group.add_argument('--indent', default=4, type=int,
39 help='separate items with newlines and use this number '
40 'of spaces for indentation')
41 group.add_argument('--tab', action='store_const', dest='indent',
42 const='\t', help='separate items with newlines and use '
43 'tabs for indentation')
44 group.add_argument('--no-indent', action='store_const', dest='indent',
45 const=None,
46 help='separate items with spaces rather than newlines')
47 group.add_argument('--compact', action='store_true',
48 help='suppress all whitespace separation (most compact)')
Benjamin Peterson940e2072014-03-21 23:17:29 -050049 options = parser.parse_args()
50
Daniel Himmelstein03257942019-12-04 01:15:19 -050051 dump_args = {
52 'sort_keys': options.sort_keys,
53 'indent': options.indent,
wim glennefefe252019-12-06 00:44:01 -060054 'ensure_ascii': options.ensure_ascii,
Daniel Himmelstein03257942019-12-04 01:15:19 -050055 }
56 if options.compact:
57 dump_args['indent'] = None
58 dump_args['separators'] = ',', ':'
59
60 with options.infile as infile, options.outfile as outfile:
Ezio Melotti057bcb42012-11-29 02:15:18 +020061 try:
Daniel Himmelstein03257942019-12-04 01:15:19 -050062 if options.json_lines:
HongWeipengf1944792018-11-07 18:09:32 +080063 objs = (json.loads(line) for line in infile)
64 else:
65 objs = (json.load(infile), )
66 for obj in objs:
Daniel Himmelstein03257942019-12-04 01:15:19 -050067 json.dump(obj, outfile, **dump_args)
HongWeipengf1944792018-11-07 18:09:32 +080068 outfile.write('\n')
Ezio Melotti057bcb42012-11-29 02:15:18 +020069 except ValueError as e:
70 raise SystemExit(e)
Christian Heimes90540002008-05-08 14:29:10 +000071
72
73if __name__ == '__main__':
74 main()