Miscellaneous tools for working with JSON in Notepad++. Includes a general-purpose tree view with powerful search capabilities.
If you have any issues, see if updating to the latest release helps, and then feel free to raise an issue on GitHub. Please be sure to include diagnostic information about your system, Notepad++ version, and plugin version (go to ?->Debug Info...
from the Notepad++ main menu).
- Pretty-print JSON so that it's spread out over multiple lines.
- Compress JSON so that it has little or no unnecessary whitespace.
- Open a drop-down tree view of the document. Selecting a node in the tree navigates to the corresponding line in the document.
- Able to parse documents that have many different syntax errors, including but not limited to:
- The full JSON5 specification
- Python-style comments
- Missing commas and colons
- Unterminated strings, arrays, and objects
- Get the path to the current position
- Query and edit JSON with:
- a find/replace form
- an array sorting form
- the RemesPath query language.
- A regex search form for viewing and editing CSV files, or doing find/replace operations that involve math.
- Parse JSON Lines documents.
- A form for gettting JSON from APIs or many different local files.
- JSON schema validation, including automatic validation based on filenames.
- Generation of random JSON
- Generation of JSON schema from JSON
- Automatic error checking after editing
- Select all JSON in a non-JSON file
- Quickly convert between JSON strings and raw text
Go to the Releases page to see past releases.
Download latest 32-bit version
You can unzip the 32-bit download to .\Program Files (x86)\Notepad++\plugins\JsonTools\JsonTools.dll
.
Download latest 64-bit version
You can unzip the 64-bit download to C:\Program Files\Notepad++\plugins\JsonTools\JsonTools.dll
.
Alternatively, you can follow these installation instructions to install the latest version of the plugin from Notepad++.
You can also download recently committed but unreleased versions of JsonTools by downloading the appropriate GitHub artifact in the following way:
- Go to the commit history of JsonTools.
- Most commits will have a green checkmark and the text
4/4
next to their commit message. Click on it. - A dropdown menu showing the CI tasks will appear. Click on one of the
Details
links. Here's an example of a page that this leads to.. - Click the
Summary
link near the top-left corner of the page. Here's an example of the page this leads to. - If you chose a commit that was made in the last 90 days, at the bottom of this page you will find links to download
plugin_dll_x64
(a zip archive containing 64-bitJsonTools.dll
) orplugin_dll_x86
(a zip archive containing 32-bitJsonTools.dll
). Download the appropriate binary for your current Notepad++ installation. - Unzip the zip archive you downloaded into a folder.
- Close Notepad++, if it was open, because you can't modify the JsonTools DLL while it's in use.
- Copy the
JsonTools.dll
inside the extracted folder into theNotepad++\plugins\JsonTools
folder under your Notepad++ installation, overwriting your old version of JsonTools (or rename the old version so that you can switch back to it)
If you also want to download the most recent translation to another language, you will need to also download the most up-to-date translation file for that language from the translation
folder of this repo. To do that:
- Click on one of the files in the list.
- Click the download icon near the top of the page.
- Put the downloaded raw
{yourLanguage}.json5
file into thetranslation
folder of your JsonTools plugin directory, as discussed in the documentation on translating JsonTools.
Every version of the plugin works on Notepad++ 8.4.1 onward, although some versions of Notepad++ have problems.
Versions of the plugin from 4.10.0.3 onward are compatible with older Notepad++ (tested for 7.3.3, may be compatible with even older).
Every version up to and including 3.7.2.1 should work natively on Windows 8 or later (note: this is untested), or you must install .NET Framework 4.0. Every version beginning with 4.0.0 works on Windows 10 May 2019 update or later, or you must install .NET Framework 4.8.
This is not a complete list of known issues with JsonTools. For that, see the issue tracker and the Changelog. This is a list of issues that emerged in recent versions of Notepad++.
- Ctrl+C and Ctrl+X do not work inside of forms for all versions of JsonTools earlier than v7.0.0 on the following Notepad++ versions:
- Notepad++ 8.6 and 8.6.1
- Notepad++ 8.6.2 onward, when the new Notepad++ setting
Enable Copy/Cut Line without selection
is turned off.
- Using the Notepad++ find/replace form can cause problems with remembered selections, and may cause issues with RemesPath queries,under the following circumstances:
- Notepad++ 8.6.3 and 8.6.4, for all versions of JsonTools.
- Notepad++ 8.6.5, for JsonTools earlier than v7.1.0.
This plugin may consume huge amounts of memory when working with really huge JSON files (say 50+ megabytes). As of version 0.3.0
, my HugeFiles plugin can break a JSON file up into chunks such that every chunk is syntactically valid JSON. This way you don't need to read the entire file into the text editor, and you can look at one chunk at a time. You can also use this plugin to perform simple find/replace operations on the entire file (maybe eventually allowing control over which sections of the file to edit). Finally, the plugin allows a very large JSON file to be broken up into separate syntactically valid JSON files, which may be easier to use.
JSMinNPP is a reasonable alternative, although as of v5.0.0
, JsonTools has comparable performance and parsing ability.
While not a JSON plugin per se, PythonScript enables Notepad++ users to customize the editor with Python scripts. Since Python has an excellent native JSON library, you could easily use this plugin to create custom scripts for working with JSON.
Because Python has good 3rd-party packages for working with YAML and TOML (two good alternatives to JSON), PythonScript could potentially be used to allow this package to work with YAML and TOML.
Visual Studio Code has native support for JSON with comments. Just go down to where the language is listed in the right side of the taskbar, and select JSON with Comments
from the drop-down menu that appears at the top of the screen.
VSCode also has a built-in JSON tree viewer and some support for searching for keys and indices in JSON.
VSCode has many useful tools for working with JSON Schema. VSCode's JSON Schema validation is much more robust than what this plugin currently offers. You can also configure the editor to automatically use a certain JSON schema to validate JSON with a certain file path. For example, you could configure the editor to always parse files with names like *tweet*.json
with the schema tweet_schema.json
. Note: as of version 4.11, a similar feature exists in this plugin.
The JSON Tools plugin provides the same pretty-print and minify functionalities as this plugin.
Finally, the Encode/Decode plugin allows fast interconversion of YAML and JSON, among other things.
Consult this list. One Emacs plugin, JSON mode, inspired the Path to current line
feature of this plugin.
Python's standard library JSON module is excellent, albeit limited to syntactically correct JSON according to the original JSON standard.
Python's package ecosystem is incredibly rich, so I can't possibly list all the useful tools here. Three that I've enjoyed working with are:
- Pandas. The Python tool for working with pretty much any kind of data. 'Nuff said.
- GenSON. A really user-friendly tool for JSON schema generation. Includes a CLI tool for JSON schema generation and a programmatic API. Has some tools for, e.g., merging two schemas, but I haven't used those tools as much.
- DeepDiff. This is super cool! It allows fast (and I mean REALLY FAST) comparison of two JSON documents to find how they differ. For instance, DeepDiff would correctly show that
{"a": [1, 2, {"b": [3, 4]}]}
and
{"a": [1, 2, {"b": [4, 4]}]}
differ in that the first element of root['a'][2]['b']
was changed from 3 to 4.
This website offers (limited) JSON->CSV conversion, pretty-printing (appears to use the same algorithm as me), minifying, JSON->XML conversion, and a pretty good tree viewer.
I expect you could find plenty of other good websites if you did some research.
If you are interested in helping users of JsonTools who don't speak English, JsonTools can be translated to other languages beginning in v8.0.
JsonTools infers your preferred language and attempts to translate in the following way:
- JsonTools checks your Notepad++
nativeLang.xml
config file (at XPath path/NotepadPlus/Native-Langue/@name
) to determine what language you prefer to use, and setslowerEnglishName
to the appropriate value. For example, if this file saysgalician
, we will attempt to translate JsonTools togalician
. - JsonTools then does one of the following:
- If
lowerEnglishName
isenglish
, it does nothing (because JsonTools is naturally in English) - Otherwise, it looks in the
translation
subdirectory of theJsonTools
plugin folder (whereJsonTools.dll
lives) for a file named{lowerEnglishName}.json5
- NOTE: because the translation files are in a subdirectory of the plugin folder, translation does not work for versions of Notepad++ older than version 8, since those older versions do not have separate folders for each plugin.
- If
- If JsonTools found
translation\{lowerEnglishName}.json5
, it attempts to parse the file. If parsing fails, a message box will appear warning the user of this.- If no translation file was found, or if parsing failed, the default English will be used.
- If parsing was successful, JsonTools will use the translation file as described below.
JsonTools only attempts to find translation files once, when Notepad++ is starting up. If you change the UI language of Notepad++, you will have to close Notepad++ and reopen it before this change will apply to JsonTools.
To be clear, JsonTools may not be in the same language of the Notepad++ UI. The steps described above represent my best effort to automatically translate JsonTools into a language that the user will find useful, without requiring the user to select their language from a list of available languages in the settings form.
To translate JsonTools to another language, just look at english.json5
in the translations directory of this repo and follow the instructions in that file.
Currently JsonTools has been translated into the following languages:
Language | First version with translation | Translator(s) | Translator is native speaker? |
---|---|---|---|
Italian | v8.0 | conky77, molsonkiko (only for messageBoxes and fileComments sections) |
Only conky77 |
The following aspects of JsonTools can be translated:
- Forms (including all controls and items in drop-down menus) (see the
forms
field of the translationjson5
file) - Items in the JsonTools sub-menu of the Notepad++ Plugins menu (see the
menuItems
field) - The descriptions of settings in the
JsonTools.ini
config file (see thesettingsDescriptions
field) - The descriptions of settings in the settings form (only for versions since v8.1) (also controlled by
settingsDescriptions
) - JSON syntax errors and JSON schema validation errors (only for versions since v8.1) (see the
jsonLint
field) - Message boxes (includes warnings, errors, requests for confirmation) (only for versions since v8.1) (see the
messageBoxes
field)
The following aspects of JsonTools may eventually be translated:
- This documentation
- Generic modal dialogs (for example, file-opening dialogs, directory selection dialogs)
- Error messsages (other than JSON syntax errors, which are already translated)
- Kasper B. Graverson for creating the plugin pack that this is based on.
- Bas de Reuver for making the excellent CSVLint plugin that I've consulted extensively in writing the code.
- jokedst for making the CsvQuery plugin to which I owe the original ideas behind my settings form and my adaptive styling of forms.
- Everyone who took the time to raise issues and help improve the plugin, especially vinsworldcom.
- And of course, Don Ho for creating Notepad++!
JsonTools sorts strings more or less the same way as other Windows applications like Microsoft Word, while Notepad++ sorts strings based on Unicode code points. This is more intuitive in some cases, and less intuitive in others.
The list below shows which things in JsonTools are case-sensitive and which are case-insensitive.
Case-sensitive sorters:
sorted
andsort_by
RemesPath functions- sort form using
Sort method
=Default
. - anything else in RemesPath that sorts things, unless specifically noted otherwise.
Case-insensitive sorters:
- sorting of object keys when the
sort_keys
global setting istrue
- sorting of object keys when the
sort_keys
argument to thestringify
RemesPath function istrue
- sort form using
Sort method
=As strings (ignoring case)
Consider this input: ["1","-2","3","o","P","ö","p"]
JsonTools case-sensitive order:
["1","-2","3","o","ö","p","P"]
JsonTools case-insensitive order:
["1","-2","3","o","ö","P","p"]
(the order of the P
and the p
is unstable)
Notepad++ case-sensitive order:
["-2","1","3","P","o","p","ö"]
Notepad++ case-insensitive order:
["-2","1","3","o","P","p","ö"]
(the order of the P
and the p
is unstable)
A summary of some major differences between Notepad++ and JsonTools in string sorting:
- The sort form ignores the leading minus sign when ordering the numbers; Notepad++ does not.
- The sort form orders
ö
betweeno
andp
(because culturally that makes sense), but Notepad++ putsö
last, because it compares the strings by Unicode code points, and non-ASCII characters likeö
come after all ASCII characters. - In case-sensitive sorts, JsonTools puts upper-case letters after lower-case letters, but Notepad++ does the opposite.
- In all sorts, JsonTools respects alphabetical order (e.g.,
P
comes aftero
whether case-sensitive or not), but Notepad++ puts all upper-case letters before all lower-case letters when in case-sensitive mode.
There are many, many rules for string comparison (and I know very few of them), and I cannot possibly cover them all here. But hopefully this warning will help you not get caught off guard.