An open library for flexible simplified-traditional Chinese text conversion.
Project description
STS 簡繁祕書
STS (Simplified-Traditional Secretary) is an open library for flexible simplified-traditional Chinese text conversion.
簡繁祕書是開源、輕巧、有彈性的中文簡繁轉換工具,也支援異體字轉換及地區慣用詞轉換。
Features 特色
- 使用與 OpenCC 格式相容的詞典檔。此外亦支援 JSON 或 YAML 格式的詞典檔。
- 可「並聯」或「串聯」組合多個詞典檔作為轉換方案,並預先儲存成單一詞典檔以加速載入。詞典檔更新時也會自動重新生成組合詞典。
- 簡繁對應、異體字對應、地區慣用詞對應等不同的對應關係皆區分至不同的詞典檔。
- 詞典及配置檔與程式本體分離,可自由修改、擴充。
- 支援一對多轉換,轉換結果可輸出為純文字、HTML、JSON 等格式。
- 支援 Unicode 組合字,例如「⿰虫鬼」視為一個字,不會因為詞典有「虫=>蟲」而被轉為「⿰蟲鬼」。
- 支援用正規表示式略過特定文字的轉換。
- 支援編碼轉換,可自訂輸入及輸出檔案的字元編碼。
Usage 使用
Installation 安裝
安裝 Python >= 3.7 (官網),然後在命令列輸入以下指令安裝(或升級至)最新版本:
pip install -U sts-lib
若要支援 YAML 格式,須額外安裝 PyYAML 套件,或改用以下指令安裝:
pip install -U sts-lib[yaml]
Command Line
-
sts --help
或sts COMMAND --help
檢視可用指令的詳細說明文檔。 -
sts convert [OPTIONs] [file ...]
執行簡繁轉換:file
為一或多個欲轉換的檔案。(省略則讀取標準輸入 STDIN)-c CONFIG
指定配置檔,可為內建配置檔名稱或自製配置檔(JSON 或 YAML)的路徑。可用的內建配置檔詳見 sts/data/config 目錄,可簡寫,例如可輸入s2t
代表使用sts/data/config/s2t.json
。-f FORMAT
指定輸出格式,可用格式如下:txt
:純文字,適合一般使用。txtm
:純文字加轉換標示。html
:加上 HTML 標記的文本,可嵌入至網頁應用程式做互動式校對。htmlpage
:加入 HTML 樣式的網頁,可直接開啟做互動式校對。json
:以 JSON 格式表示轉換輸出,可用其他程式進一步解析處理。
--exclude PATTERN
指定用於忽略簡繁轉換的正規表示式。有指定return
(或return1
,return2
, ... 等)子群組時會取代為子群組的值。- 例如
sts convert -c s2twp --exclude "「.*?」"
會把「程序」正义
轉換為「程序」正義
。 - 例如
sts convert -c s2twp --exclude "-{(?P<return>.*?)}-"
會把-{程序}-正义
轉換為程序正義
。
- 例如
--in-enc ENCODING
指定輸入編碼。可用編碼參見這裡。--out-enc ENCODING
指定輸出編碼。可用編碼參見這裡。-o OUTPUT
可重覆多次,指定對應輸入檔案轉換結果的輸出路徑。(無對應者輸出至原檔)--stdout
將所有轉換結果輸出至標準輸出 STDOUT。
Python
from sts import StsMaker, StsConverter
# generate a dictionary file from a config and get its path
dictfile = StsMaker().make('s2t', quiet=True)
# initialize a converter from the dictionary file
converter = StsConverter(dictfile)
# perform conversion for a string
converter.convert_text('汉字', format='txt', exclude=None) # 漢字
# perform conversion for a file (None for stdin/stdout)
converter.convert_file(input=None, output=None
input_encoding='UTF-8', output_encoding='UTF-8',
format='txt', exclude=None)
# perform a conversion for a string and process the result data generator
[p for p in converter.convert("干了吧")] # [StsDictConv(key=['干', '了'], values=['幹了', '乾了']), '吧']
Advanced 進階開發
Config 配置檔
配置檔為 JSON 或 YAML 檔案(副檔名須為 .yaml
或 .yml
)。規格如下:
/**
* @typedef {Object} configScheme
* @property {string} [name] - name/description of the config
* @property {string[]} [requires] - required configs, which are made before
* making from this config, as an absolute path, or a path relative to the
* directory of this config file, or the basename of a built-in config file
* (with or without extension ".json", ".yaml", ".yml")
* @property {srcDictScheme[]} dicts - schemes of each dictionary file to be
* generated or loaded.
*/
/**
* A dictScheme or string for a dict.
*
* The string should be an absolute path, or a path relative to the directory
* of the config file, or the basename of a built-in dictionary file, with a
* file extension of .txt, .list, .json, .jlist, .yaml, or .yml.
*
* @typedef {(string|dictScheme)} srcDictScheme
*/
/**
* @typedef {Object} dictScheme
* @property {string} [file] - path of the dictionary file to generate, as an
* absolute path, or a path relative to the directory of this config file.
* It should be a .tlist (compiled trie), .jlist (compiled table), or .list
* (plain text table). An unknown file extension is treated as .list. `src`
* must exist when omitted.
* @property {string} [mode=load] - the mode to handle the loaded dicts.
* - "load" to simply merge the loaded keys and values;
* - "swap" to reverse the dict (i.e. use the values as keys and the keys
* as values);
* - "join" to chain dicts (a conversion using a dict joining dict1 and
* dict2 works like a conversion using dict1 and then dict2, but takes
* care of word segmentation);
* - "filter" to filter the output values in the loaded dicts with extra
* "include" and "exclude" properties
* - "expand" to expand the placeholders (defined in the extra
* "placeholders" property) in the first dict with the matching key and
* values in other dicts;
* - "remove_keys" to remove keys from the first dict if it appears in any
* other one;
* - "remove_values" to remove key-value pairs from the first dict if it
* appears in any other one.
* @property {srcDictScheme[]} [src] - the source dicts. `file` must exist when
* omitted.
* @property {boolean} [sort] - true to sort the keys of the output dictionary.
* @property {boolean} [check] - true to raise an exception if the output
* contains an invalid char which will be loaded incorrectly. Set this
* when the output is a plain text table file and the source files contain
* untrusted JSON or YAML data that may include a char like " ", "\t",
* "\n", etc. in the dictionary.
* @property {string} [include] - a regex filter that discards non-matched
* conversion values. (for "filter" mode)
* @property {string} [exclude] - a regex filter that discards matched
* conversion values. (for "filter" mode)
* @property {string[]} [placeholders] - strings to be expanded using other
* dicts. (for "expand" mode)
*/
Dictionary 詞典檔
原始詞典檔可為純文字、JSON、或 YAML。編譯產生的詞典檔有純文字(.list
)、JSON列表(.jlist
)、JSON樹(.tlist
)三種格式,其中前二者可再作為原始檔輸入,後者則只能用於轉換。
純文字
純文字詞典副檔名為 .txt
或 .list
。規格為以 TAB 字元分隔輸入詞與轉換詞,多個轉換詞之間以半形空白分隔,如下:
輸入詞1\t轉換詞11 轉換詞12 ...
輸入詞2\t轉換詞21 轉換詞22 ...
...
注意,使用此格式時,輸入詞不可含有 TAB 字元,轉換詞不可含有半形空白字元。此外二者也不可含有換行等字元。
JSON
JSON 詞典副檔名為 .json
或 .jlist
。規格如下:
{
"輸入詞1": "轉換詞11",
"輸入詞2": ["轉換詞21"],
"輸入詞3": ["轉換詞31", "轉換詞32", ...],
...
}
YAML
YAML 詞典副檔名為 .yaml
或 .yml
。規格如下:
輸入詞1: 轉換詞11
輸入詞2: [轉換詞21]
輸入詞3: [轉換詞31, 轉換詞32, ...]
...
線上版
本線上轉換工具支援文字轉換及檔案轉換。前者只要在輸入區填入文字,就會自動轉換並且可以互動式校訂。後者可以用按鈕或拖放選擇一或多個檔案,就會逐一轉換後自動下載。預設檔案輸入輸出編碼皆是UTF-8,如要輸入其他編碼的檔案,可在進階選項設定。
目前內建 OpenCC、MediaWiki、新同文堂的轉換方案,並且修正了 OpenCC 演算法缺陷導致一些地區詞無法正常轉換的問題(詳見相關問題回報)。
License 許可協議
本專案以 Apache License 2.0 協議授權使用。
詞典檔原始資料來自同文堂、維基百科、OpenCC 等開源專案,再按本專案之需求編校。
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.