Skip to content

CanCLID/canto-filter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

粵文分類篩選器

license

English

簡介

呢個係個粵文篩選器,用嚟區分粵語同官話文本,對於篩選粵語語料好有用。個分類器會將輸入文本分成四類:

  1. cantonese: 純粵文,僅含有粵語特徵字詞,例如“你喺邊度”
  2. mandarin: 純官話文,僅含有官話特徵字詞,例如“你在哪裏”
  3. mixed:官粵混雜文,同時含有官話同粵語特徵嘅字詞,例如“是咁的”
  4. neutral:無特徵漢語文,唔含有官話同粵語特徵,既可以當成粵文亦可以當成官話文,例如“去學校讀書”

分類方法係官話同粵語嘅特徵字詞識別。如果同時含有官話同粵語特徵詞彙就算官粵混雜,如果唔含有任何特徵,就算冇特徵中性文本。

設計思想同假設

本篩選器嘅主要設計目標係「篩選出可以用作訓練數據嘅優質粵文」,而非「準確分類輸入文本」。所以喺判斷粵語/官話嗰陣會用偏嚴格嘅判別標準,即係會犧牲 recall 嚟換取高 precision (寧願篩漏粵文句子都唔好將官話文誤判成粵文)。

本篩選器默認所有輸入文本都用推薦用字方案書寫。如果輸入文本採用其他用字方案(有錯別字),會影響分類篩選結果。例如輸入畀本書我分類器會輸出cantonese,但寫成比本書我會輸出neutral。你可以用錯別字修正器嚟清洗被分成neutral嘅文本,噉樣可能會得到更多粵文。

呢隻篩選器默認所有輸入文本都係傳統漢字。如果要分類簡化字文本,要將佢哋轉化成傳統漢字先。推薦使用 OpenCC嚟轉換。

引用本篩選器

本工具以字詞特徵抽出「純粵文」文本嘅策略同埋實踐方式。呢個策略首先喺以下場合提出。討論本分類器時,請引用:

Lau, Chaak Ming (劉擇明). 2022. Lingusitic features and automatic detection of Hong Kong-style Written Chinese and Cantonese Writing (港式書面語和粵語書寫的語言學特徵和自動辨識). Paper presented at the 26th International Conference of Yue Dialects (第二十六屆國際粵方言研討會).

「粵文」同「官話文」嘅定義同界線取決於使用者嘅語言意識形態,呢度嘅分類方法以下文所描述嘅粵文書寫體作為基礎。討論本工具採取嘅分類準則,請引用:

Lau, Chaak Ming. 2024. Ideologically driven divergence in Cantonese vernacular writing practices. In J.-F. Dupré, editor, Politics of Language in Hong Kong, Routledge.

依賴

Python >= 3.11

用法

首先用 pip 安裝

pip install canto-filter

你可以喺 Python 代碼入面用,亦都可以直接喺命令行入面用。

Python 函數用法

本篩選器剩得一個函數 judge(),輸入一句話輸出佢嘅語言分類:

from cantofilter import judge

print(judge('你喺邊度')) # cantonese
print(judge('你在哪裏')) # mandarin
print(judge('是咁的'))  # mixed
print(judge('去學校讀書'))  # neutral

命令行用法

首先要有一個輸入文檔,例如input.txt,入面每行一個句子.

輸出標籤同原文

然後運行下面命令

cantofilter --input input.txt > output.txt

噉樣會得到一個 output.txt,入面有由 \t 分成嘅兩列,第一列係判斷標籤,第二列係句子原文本。

僅輸出一類

如果你想直接篩選出某一類嘅文本,噉可以加一個 --mode <LABEL> 參數喺後面,例如

cantofilter --input input.txt --mode cantonese > output.txt

噉樣輸出嘅 output.txt 就會係純粵文句子。如果想剩係要官話、官粵混合或者中性文本,將個 --mode 參數定成 mandarinmixedneutral就得。

僅輸出標籤

你亦都可以剩係輸出啲句子嘅分類結果,用 --mode label 就得:

cantofilter --input input.txt --mode label > output.txt

噉樣嘅 output.txt 剩得一列,全部都係分類標籤。

Cantonese text filter

Overview

This is a text filter for Cantonese, designed for filtering Cantonese text corpus. It classifies input sentences with four output labels:

  1. cantonese: Pure Cantonese text, contains Cantonese-featured words. E.g. 你喺邊度
  2. mandarin: Pure Mandarin text, contains Mandarin-feature words. E.g. 你在哪裏
  3. mixed:Mixed Cantonese-Mandarin text, contains both Cantonese and Mandarin-featured words. E.g. 是咁的
  4. neutral:No feature Chinese text, contains neither Cantonese nor Mandarin feature words. Such sentences can be used for both Cantonese and Mandarin text corpus. E.g. 去學校讀書

The filter is regex rule-based, by detecting Mandarin and Cantonese feature characters and words. If a sentence contains both Cantonese and Mandarin feature words, then it is a mixed-Cantonese-Mandarin sentence. If it contains neither features, it is a no-feature, neutral Chinese text.

Design priciples and assumptions

This filter is designed for the purpose of "obtaining high-quality Cantonese text", as opposed to "accurately classifying input texts". Therefore, it maximizes precision at the price of recall, to minimize the false positive rate / avoid including potential Mandarin sentences (we rather miss some Cantonese sentences, than mistaking potential Mandarin sentences as Cantonese).

This filter assumes all input text written in the recommended orthography. Spelling errors or typos in input text might affect the classification result. For instance, 畀本書我 yields cantonese, while 比本書我 yields neutral. You can use the spelling corrector to correct the neutral text, which might give you more Cantonese text.

This filter assumes all input text in Traditional Chinese characters. If you want to filter texts written in simplified characters, please convert them into Traditional characters first. We recommend using OpenCC to do the conversion.

Citing this package

The implementation and methodology of this filter was first proposed in the following contexts. below. When discussing this filter, please cite:

Lau, Chaak Ming (劉擇明). 2022. Lingusitic features and automatic detection of Hong Kong-style Written Chinese and Cantonese Writing (港式書面語和粵語書寫的語言學特徵和自動辨識). Paper presented at the 26th International Conference of Yue Dialects (第二十六屆國際粵方言研討會).

The definitions and boundaries of 'Cantonese text' and 'Mandarin text' depend on the user's language ideology. The classification method used here is based on the Cantonese written style described in the following text. When discussing the criteria adopted by this tool, please cite:

Lau, Chaak Ming. 2024. Ideologically driven divergence in Cantonese vernacular writing practices. In J.-F. Dupré, editor, Politics of Language in Hong Kong, Routledge.

Requirement

Python >= 3.11

How to use

Install the package with pip first

pip install canto-filter

This package can be used in python codes, or as a CLI tool.

Python function usage

There is only one function in this package, judge(), which accepts a string input and outputs one of the labels:

from cantofilter import judge

print(judge('你喺邊度')) # cantonese
print(judge('你在哪裏')) # mandarin
print(judge('是咁的'))  # mixed
print(judge('去學校讀書'))  # neutral

CLI usage

Assume an input text file, e.g. input.txt where each line is a sentence.

Output both labels and original texts

Then run

cantofilter --input input.txt > output.txt

There will be a output.txt which has two columns. The first column is the language label, and the second column is the original input text.

Output only text of one class

If you want only one class of text, use the --mode <LABEL> argument. Say if you want pure Cantonese text only:

cantofilter --input input.txt --mode cantonese > output.txt

The output.txt will contain only Cantonese text.

Output label only

If you want to include the classification labels in the output, use --mode label like this:

cantofilter --input input.txt --mode label > output.txt

Then your output.txt will contain only classification results of the input sentences.