| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  | r"""Command-line tool to validate and pretty-print JSON
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Usage:: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-02 12:36:44 +00:00
										 |  |  |     $ echo '{"json":"obj"}' | python -m json.tool | 
					
						
							| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         "json": "obj" | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-05-02 12:36:44 +00:00
										 |  |  |     $ echo '{ 1.2:3.4}' | python -m json.tool | 
					
						
							| 
									
										
										
										
											2013-02-21 20:19:16 +02:00
										 |  |  |     Expecting property name enclosed in double quotes: line 1 column 3 (char 2) | 
					
						
							| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | """
 | 
					
						
							| 
									
										
										
										
											2014-03-21 23:17:29 -05:00
										 |  |  | import argparse | 
					
						
							| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  | import json | 
					
						
							| 
									
										
										
										
											2014-03-21 23:17:29 -05:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2021-11-06 18:11:35 +01:00
										 |  |  | from pathlib import Path | 
					
						
							| 
									
										
										
										
											2014-03-21 23:17:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def main(): | 
					
						
							| 
									
										
										
										
											2014-03-21 23:17:29 -05:00
										 |  |  |     prog = 'python -m json.tool' | 
					
						
							|  |  |  |     description = ('A simple command line interface for json module ' | 
					
						
							|  |  |  |                    'to validate and pretty-print JSON objects.') | 
					
						
							|  |  |  |     parser = argparse.ArgumentParser(prog=prog, description=description) | 
					
						
							| 
									
										
										
										
											2019-12-04 18:39:31 +09:00
										 |  |  |     parser.add_argument('infile', nargs='?', | 
					
						
							|  |  |  |                         type=argparse.FileType(encoding="utf-8"), | 
					
						
							| 
									
										
										
										
											2019-05-14 18:52:42 +02:00
										 |  |  |                         help='a JSON file to be validated or pretty-printed', | 
					
						
							|  |  |  |                         default=sys.stdin) | 
					
						
							| 
									
										
										
										
											2019-12-04 18:39:31 +09:00
										 |  |  |     parser.add_argument('outfile', nargs='?', | 
					
						
							| 
									
										
										
										
											2021-11-06 18:11:35 +01:00
										 |  |  |                         type=Path, | 
					
						
							| 
									
										
										
										
											2019-05-14 18:52:42 +02:00
										 |  |  |                         help='write the output of infile to outfile', | 
					
						
							| 
									
										
										
										
											2021-11-06 18:11:35 +01:00
										 |  |  |                         default=None) | 
					
						
							| 
									
										
										
										
											2014-11-10 09:56:54 +02:00
										 |  |  |     parser.add_argument('--sort-keys', action='store_true', default=False, | 
					
						
							|  |  |  |                         help='sort the output of dictionaries alphabetically by key') | 
					
						
							| 
									
										
										
										
											2019-12-06 00:44:01 -06:00
										 |  |  |     parser.add_argument('--no-ensure-ascii', dest='ensure_ascii', action='store_false', | 
					
						
							|  |  |  |                         help='disable escaping of non-ASCII characters') | 
					
						
							| 
									
										
										
										
											2018-11-07 18:09:32 +08:00
										 |  |  |     parser.add_argument('--json-lines', action='store_true', default=False, | 
					
						
							| 
									
										
										
										
											2019-12-07 07:14:40 -07:00
										 |  |  |                         help='parse input using the JSON Lines format. ' | 
					
						
							|  |  |  |                         'Use with --no-indent or --compact to produce valid JSON Lines output.') | 
					
						
							| 
									
										
										
										
											2019-12-04 01:15:19 -05:00
										 |  |  |     group = parser.add_mutually_exclusive_group() | 
					
						
							|  |  |  |     group.add_argument('--indent', default=4, type=int, | 
					
						
							|  |  |  |                        help='separate items with newlines and use this number ' | 
					
						
							|  |  |  |                        'of spaces for indentation') | 
					
						
							|  |  |  |     group.add_argument('--tab', action='store_const', dest='indent', | 
					
						
							|  |  |  |                        const='\t', help='separate items with newlines and use ' | 
					
						
							|  |  |  |                        'tabs for indentation') | 
					
						
							|  |  |  |     group.add_argument('--no-indent', action='store_const', dest='indent', | 
					
						
							|  |  |  |                        const=None, | 
					
						
							|  |  |  |                        help='separate items with spaces rather than newlines') | 
					
						
							|  |  |  |     group.add_argument('--compact', action='store_true', | 
					
						
							|  |  |  |                        help='suppress all whitespace separation (most compact)') | 
					
						
							| 
									
										
										
										
											2014-03-21 23:17:29 -05:00
										 |  |  |     options = parser.parse_args() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-04 01:15:19 -05:00
										 |  |  |     dump_args = { | 
					
						
							|  |  |  |         'sort_keys': options.sort_keys, | 
					
						
							|  |  |  |         'indent': options.indent, | 
					
						
							| 
									
										
										
										
											2019-12-06 00:44:01 -06:00
										 |  |  |         'ensure_ascii': options.ensure_ascii, | 
					
						
							| 
									
										
										
										
											2019-12-04 01:15:19 -05:00
										 |  |  |     } | 
					
						
							|  |  |  |     if options.compact: | 
					
						
							|  |  |  |         dump_args['indent'] = None | 
					
						
							|  |  |  |         dump_args['separators'] = ',', ':' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 18:11:35 +01:00
										 |  |  |     with options.infile as infile: | 
					
						
							| 
									
										
										
										
											2012-11-29 02:15:18 +02:00
										 |  |  |         try: | 
					
						
							| 
									
										
										
										
											2019-12-04 01:15:19 -05:00
										 |  |  |             if options.json_lines: | 
					
						
							| 
									
										
										
										
											2018-11-07 18:09:32 +08:00
										 |  |  |                 objs = (json.loads(line) for line in infile) | 
					
						
							|  |  |  |             else: | 
					
						
							| 
									
										
										
										
											2021-11-06 18:11:35 +01:00
										 |  |  |                 objs = (json.load(infile),) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if options.outfile is None: | 
					
						
							|  |  |  |                 out = sys.stdout | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 out = options.outfile.open('w', encoding='utf-8') | 
					
						
							|  |  |  |             with out as outfile: | 
					
						
							|  |  |  |                 for obj in objs: | 
					
						
							|  |  |  |                     json.dump(obj, outfile, **dump_args) | 
					
						
							|  |  |  |                     outfile.write('\n') | 
					
						
							| 
									
										
										
										
											2012-11-29 02:15:18 +02:00
										 |  |  |         except ValueError as e: | 
					
						
							|  |  |  |             raise SystemExit(e) | 
					
						
							| 
									
										
										
										
											2008-05-08 14:29:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == '__main__': | 
					
						
							| 
									
										
										
										
											2020-03-10 16:41:44 +09:00
										 |  |  |     try: | 
					
						
							|  |  |  |         main() | 
					
						
							|  |  |  |     except BrokenPipeError as exc: | 
					
						
							|  |  |  |         sys.exit(exc.errno) |