GNU/Linux >> Znalost Linux >  >> Linux

Zjištění, jaké znaky daný font podporuje

fontconfig příkazy mohou vypsat seznam glyfů jako kompaktní seznam rozsahů, např.:

$ fc-match --format='%{charset}\n' OpenSans
20-7e a0-17f 192 1a0-1a1 1af-1b0 1f0 1fa-1ff 218-21b 237 2bc 2c6-2c7 2c9
2d8-2dd 2f3 300-301 303 309 30f 323 384-38a 38c 38e-3a1 3a3-3ce 3d1-3d2 3d6
400-486 488-513 1e00-1e01 1e3e-1e3f 1e80-1e85 1ea0-1ef9 1f4d 2000-200b
2013-2015 2017-201e 2020-2022 2026 2030 2032-2033 2039-203a 203c 2044 2070
2074-2079 207f 20a3-20a4 20a7 20ab-20ac 2105 2113 2116 2120 2122 2126 212e
215b-215e 2202 2206 220f 2211-2212 221a 221e 222b 2248 2260 2264-2265 25ca
fb00-fb04 feff fffc-fffd

Použijte fc-query pro .ttf soubor a fc-match pro název nainstalovaného písma.

To pravděpodobně nezahrnuje instalaci žádných extra balíčků a nezahrnuje překlad bitmapy.

Použijte fc-match --format='%{file}\n' zkontrolovat, zda se shoduje správné písmo.


Program X xfd můžete to udělat. Chcete-li zobrazit všechny znaky pro písmo "DejaVu Sans Mono", spusťte:

xfd -fa "DejaVu Sans Mono"

Je součástí balíčku x11-utils na Debian/Ubuntu, xorg-x11-apps na Fedoře/RHEL a xorg-xfd na Arch Linuxu.


Zde je metoda využívající knihovnu fontTools Python (kterou můžete nainstalovat pomocí něčeho jako pip install fonttools ):

#!/usr/bin/env python
from itertools import chain
import sys

from fontTools.ttLib import TTFont
from fontTools.unicode import Unicode

with TTFont(
    sys.argv[1], 0, allowVID=0, ignoreDecompileErrors=True, fontNumber=-1
) as ttf:
    chars = chain.from_iterable(
        [y + (Unicode[y[0]],) for y in x.cmap.items()] for x in ttf["cmap"].tables
    )
    if len(sys.argv) == 2:  # print all code points
        for c in chars:
            print(c)
    elif len(sys.argv) >= 3:  # search code points / characters
        code_points = {c[0] for c in chars}
        for i in sys.argv[2:]:
            code_point = int(i)   # search code point
            #code_point = ord(i)  # search character
            print(Unicode[code_point])
            print(code_point in code_points)

Skript bere jako argumenty cestu k písmu a volitelně kódové body / znaky, které se mají hledat:

$ python checkfont.py /usr/share/fonts/**/DejaVuSans.ttf
(32, 'space', 'SPACE')
(33, 'exclam', 'EXCLAMATION MARK')
(34, 'quotedbl', 'QUOTATION MARK')
…

$ python checkfont.py /usr/share/fonts/**/DejaVuSans.ttf 65 12622  # a ㅎ
LATIN CAPITAL LETTER A
True
HANGUL LETTER HIEUH
False

fc-query my-font.ttf vám poskytne mapu podporovaných glyfů a všech lokalit, pro které je písmo vhodné podle fontconfig

Protože téměř všechny moderní linuxové aplikace jsou založeny na fontconfig, je to mnohem užitečnější než surový seznam unicode

Skutečný výstupní formát je diskutován zdehttp://lists.freedesktop.org/archives/fontconfig/2013-September/004915.html


Linux
  1. Jakou verzi Linuxu používám? Zde je návod, jak to zjistit

  2. Jak zjistit, co dělá příkaz Linuxu

  3. Je možné zjistit, jaký program nebo skript vytvořil daný soubor?

  1. Rozdělit jednotlivé znaky pomocí řetězce Null?

  2. Jak zjistit, zda systém podporuje Intel Amt?

  3. Jak zjistit, jakou skupinu daný uživatel má?

  1. Jaké znaky jsou v názvech adresářů Windows a Linux zakázány?

  2. Získejte poslední 4 znaky výstupu ze standardního výstupu

  3. Jaký je unixový příkaz ke zjištění, jaký spustitelný soubor odpovídá danému příkazu?