diff options
author | Walter Purcaro <vuolter@users.noreply.github.com> | 2015-04-07 22:22:18 +0200 |
---|---|---|
committer | Walter Purcaro <vuolter@users.noreply.github.com> | 2015-04-07 22:22:18 +0200 |
commit | d2fe85670726901da627490da4155af972c1a62e (patch) | |
tree | b8931d070a51b6d8b1dabe881f54504f9d9ef6de /lib/simplejson/tool.py | |
parent | Update user-agent (diff) | |
parent | fix gui (diff) | |
download | pyload-d2fe85670726901da627490da4155af972c1a62e.tar.xz |
Merge branch 'pr/n1_ardi69' into 0.4.10
Diffstat (limited to 'lib/simplejson/tool.py')
-rw-r--r-- | lib/simplejson/tool.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/lib/simplejson/tool.py b/lib/simplejson/tool.py new file mode 100644 index 000000000..73370db55 --- /dev/null +++ b/lib/simplejson/tool.py @@ -0,0 +1,39 @@ +r"""Command-line tool to validate and pretty-print JSON + +Usage:: + + $ echo '{"json":"obj"}' | python -m simplejson.tool + { + "json": "obj" + } + $ echo '{ 1.2:3.4}' | python -m simplejson.tool + Expecting property name: line 1 column 2 (char 2) + +""" +import sys +import simplejson as json + +def main(): + if len(sys.argv) == 1: + infile = sys.stdin + outfile = sys.stdout + elif len(sys.argv) == 2: + infile = open(sys.argv[1], 'rb') + outfile = sys.stdout + elif len(sys.argv) == 3: + infile = open(sys.argv[1], 'rb') + outfile = open(sys.argv[2], 'wb') + else: + raise SystemExit(sys.argv[0] + " [infile [outfile]]") + try: + obj = json.load(infile, + object_pairs_hook=json.OrderedDict, + use_decimal=True) + except ValueError, e: + raise SystemExit(e) + json.dump(obj, outfile, sort_keys=True, indent=' ', use_decimal=True) + outfile.write('\n') + + +if __name__ == '__main__': + main() |