improve the command-line interface of json.tool (closes #21000)

A patch from Berker Peksag.
This commit is contained in:
Benjamin Peterson 2014-03-21 23:17:29 -05:00
parent a191b91a43
commit 940e207412
4 changed files with 76 additions and 12 deletions

View File

@ -104,6 +104,8 @@ Using json.tool from the shell to validate and pretty-print::
$ echo '{1.2:3.4}' | python -mjson.tool $ echo '{1.2:3.4}' | python -mjson.tool
Expecting property name enclosed in double quotes: line 1 column 2 (char 1) Expecting property name enclosed in double quotes: line 1 column 2 (char 1)
See :ref:`json-commandline` for detailed documentation.
.. highlight:: python3 .. highlight:: python3
.. note:: .. note::
@ -563,3 +565,52 @@ the last name-value pair for a given name::
{'x': 3} {'x': 3}
The *object_pairs_hook* parameter can be used to alter this behavior. The *object_pairs_hook* parameter can be used to alter this behavior.
.. highlight:: bash
.. _json-commandline:
Command Line Interface
----------------------
The :mod:`json.tool` module provides a simple command line interface to validate
and pretty-print JSON objects.
If the optional :option:`infile` and :option:`outfile` arguments are not
specified, :attr:`sys.stdin` and :attr:`sys.stdout` will be used respectively::
$ echo '{"json": "obj"}' | python -m json.tool
{
"json": "obj"
}
$ echo '{1.2:3.4}' | python -m json.tool
Expecting property name enclosed in double quotes: line 1 column 2 (char 1)
Command line options
^^^^^^^^^^^^^^^^^^^^
.. cmdoption:: [<infile>]
The JSON file to be validated or pretty-printed::
$ python -m json.tool mp_films.json
[
{
"title": "And Now for Something Completely Different",
"year": 1971
},
{
"title": "Monty Python and the Holy Grail",
"year": 1975
}
]
.. cmdoption:: [<outfile>]
Write the output of the *infile* to the given *outfile*. Otherwise, write it
to :attr:`sys.stdout`.
.. cmdoption:: -h, --help
Show the help message.

View File

@ -10,21 +10,24 @@ Usage::
Expecting property name enclosed in double quotes: line 1 column 3 (char 2) Expecting property name enclosed in double quotes: line 1 column 3 (char 2)
""" """
import sys import argparse
import json import json
import sys
def main(): def main():
if len(sys.argv) == 1: prog = 'python -m json.tool'
infile = sys.stdin description = ('A simple command line interface for json module '
outfile = sys.stdout 'to validate and pretty-print JSON objects.')
elif len(sys.argv) == 2: parser = argparse.ArgumentParser(prog=prog, description=description)
infile = open(sys.argv[1], 'r') parser.add_argument('infile', nargs='?', type=argparse.FileType(),
outfile = sys.stdout help='a JSON file to be validated or pretty-printed')
elif len(sys.argv) == 3: parser.add_argument('outfile', nargs='?', type=argparse.FileType('w'),
infile = open(sys.argv[1], 'r') help='write the output of infile to outfile')
outfile = open(sys.argv[2], 'w') options = parser.parse_args()
else:
raise SystemExit(sys.argv[0] + " [infile [outfile]]") infile = options.infile or sys.stdin
outfile = options.outfile or sys.stdout
with infile: with infile:
try: try:
obj = json.load(infile) obj = json.load(infile)

View File

@ -55,6 +55,7 @@ class TestTool(unittest.TestCase):
def test_infile_stdout(self): def test_infile_stdout(self):
infile = self._create_infile() infile = self._create_infile()
rc, out, err = assert_python_ok('-m', 'json.tool', infile) rc, out, err = assert_python_ok('-m', 'json.tool', infile)
self.assertEqual(rc, 0)
self.assertEqual(out.splitlines(), self.expect.encode().splitlines()) self.assertEqual(out.splitlines(), self.expect.encode().splitlines())
self.assertEqual(err, b'') self.assertEqual(err, b'')
@ -65,5 +66,12 @@ class TestTool(unittest.TestCase):
self.addCleanup(os.remove, outfile) self.addCleanup(os.remove, outfile)
with open(outfile, "r") as fp: with open(outfile, "r") as fp:
self.assertEqual(fp.read(), self.expect) self.assertEqual(fp.read(), self.expect)
self.assertEqual(rc, 0)
self.assertEqual(out, b'') self.assertEqual(out, b'')
self.assertEqual(err, b'') self.assertEqual(err, b'')
def test_help_flag(self):
rc, out, err = assert_python_ok('-m', 'json.tool', '-h')
self.assertEqual(rc, 0)
self.assertTrue(out.startswith(b'usage: '))
self.assertEqual(err, b'')

View File

@ -23,6 +23,8 @@ Core and Builtins
Library Library
------- -------
- Issue #21000: Improve the command-line interface of json.tool.
- Issue #20995: Enhance default ciphers used by the ssl module to enable - Issue #20995: Enhance default ciphers used by the ssl module to enable
better security an prioritize perfect forward secrecy. better security an prioritize perfect forward secrecy.