ttxjson is a Python tool that converts an SFNT font (OTF, TTF)
into JSON, using the fontTools
and jsonpickle
Python modules.
- Download and unzip https://github.com/twardoch/fonttools-utils/archive/master.zip
- Open Terminal and navigate to the folder where you’ve unzipped the archive.
- Type these lines one by one, enter the Administrator password after the first "sudo" line:
pip install --user git+https://github.com/fonttools/fonttools.git
pip install --user git+https://github.com/jsonpickle/jsonpickle.git
cd ttxjson
chmod gou+x ttxjson.py
sudo mkdir -p /usr/local/bin
sudo cp ttxjson.py /usr/local/bin
- Test if the tool is available in Terminal by typing
ttxjson.py -h
usage: ttxjson.py [-h] [-o OUTPUT] [-t TABLES] infontpath
ttxjson.py is a Python tool that converts an SFNT font (OTF, TTF) into JSON.
Homepage: https://github.com/twardoch/fonttools-utils/
positional arguments:
infontpath Input SFNT font file (.otf, .ttf)
optional arguments:
-h, --help show this help message and exit
-o OUTPUT, --output OUTPUT
Output JSON path, stdout if not given
-t TABLES, --tables TABLES
Comma-separated list of SFNT tables, e.g.
CFF,head,name
import ttxjson
import fontTools.ttLib
font = fontTools.ttLib.TTFont(fontPath, lazy=False, ignoreDecompileErrors=True)
jsonString = ttxjson.ttxJson(font, tables=['head','name','CFF '])
print jsonString
import json
jsonDict = json.loads(jsonString)
upm = jsonDict[u'tables'][u'head'][u'unitsPerEm']
print upm
This tool is licensed “as is” under the Apache License, Version 2.0. By using the tool, you accept all conditions of the license, including Disclaimer of Warranty and Limitation of Liability. If you use this tool, please consult if your font’s EULA allows modifications. If the font is licensed under the OFL, please use the -R
option to change the Reserved Font Name to something else.
This tool is written in Python 2.7 and requires fontTools
and jsonpickle
.
- Code by Adam Twardoch
- Homepage: https://github.com/twardoch/fonttools-utils/