|
|
|
@ -3,25 +3,19 @@ import re
|
|
|
|
|
|
|
|
|
|
# jieba静音
|
|
|
|
|
import jieba
|
|
|
|
|
|
|
|
|
|
jieba.setLogLevel(logging.CRITICAL)
|
|
|
|
|
|
|
|
|
|
# 更改fast_langdetect大模型位置
|
|
|
|
|
from pathlib import Path
|
|
|
|
|
import fast_langdetect
|
|
|
|
|
|
|
|
|
|
fast_langdetect.infer._default_detector = fast_langdetect.infer.LangDetector(
|
|
|
|
|
fast_langdetect.infer.LangDetectConfig(
|
|
|
|
|
cache_dir=Path(__file__).parent.parent.parent / "pretrained_models" / "fast_langdetect"
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
fast_langdetect.infer._default_detector = fast_langdetect.infer.LangDetector(fast_langdetect.infer.LangDetectConfig(cache_dir=Path(__file__).parent.parent.parent / "pretrained_models" / "fast_langdetect"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from split_lang import LangSplitter
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def full_en(text):
|
|
|
|
|
pattern = r"^(?=.*[A-Za-z])[A-Za-z0-9\s\u0020-\u007E\u2000-\u206F\u3000-\u303F\uFF00-\uFFEF]+$"
|
|
|
|
|
pattern = r'^(?=.*[A-Za-z])[A-Za-z0-9\s\u0020-\u007E\u2000-\u206F\u3000-\u303F\uFF00-\uFFEF]+$'
|
|
|
|
|
return bool(re.match(pattern, text))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -40,7 +34,7 @@ def full_cjk(text):
|
|
|
|
|
(0x2EBF0, 0x2EE5D), # CJK Extension H
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
pattern = r"[0-9、-〜。!?.!?… /]+$"
|
|
|
|
|
pattern = r'[0-9、-〜。!?.!?… /]+$'
|
|
|
|
|
|
|
|
|
|
cjk_text = ""
|
|
|
|
|
for char in text:
|
|
|
|
@ -59,28 +53,28 @@ def split_jako(tag_lang, item):
|
|
|
|
|
|
|
|
|
|
lang_list: list[dict] = []
|
|
|
|
|
tag = 0
|
|
|
|
|
for match in re.finditer(pattern, item["text"]):
|
|
|
|
|
for match in re.finditer(pattern, item['text']):
|
|
|
|
|
if match.start() > tag:
|
|
|
|
|
lang_list.append({"lang": item["lang"], "text": item["text"][tag : match.start()]})
|
|
|
|
|
lang_list.append({'lang':item['lang'],'text':item['text'][tag:match.start()]})
|
|
|
|
|
|
|
|
|
|
tag = match.end()
|
|
|
|
|
lang_list.append({"lang": tag_lang, "text": item["text"][match.start() : match.end()]})
|
|
|
|
|
lang_list.append({'lang':tag_lang,'text':item['text'][match.start():match.end()]})
|
|
|
|
|
|
|
|
|
|
if tag < len(item["text"]):
|
|
|
|
|
lang_list.append({"lang": item["lang"], "text": item["text"][tag : len(item["text"])]})
|
|
|
|
|
if tag < len(item['text']):
|
|
|
|
|
lang_list.append({'lang':item['lang'],'text':item['text'][tag:len(item['text'])]})
|
|
|
|
|
|
|
|
|
|
return lang_list
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def merge_lang(lang_list, item):
|
|
|
|
|
if lang_list and item["lang"] == lang_list[-1]["lang"]:
|
|
|
|
|
lang_list[-1]["text"] += item["text"]
|
|
|
|
|
if lang_list and item['lang'] == lang_list[-1]['lang']:
|
|
|
|
|
lang_list[-1]['text'] += item['text']
|
|
|
|
|
else:
|
|
|
|
|
lang_list.append(item)
|
|
|
|
|
return lang_list
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class LangSegmenter:
|
|
|
|
|
class LangSegmenter():
|
|
|
|
|
# 默认过滤器, 基于gsv目前四种语言
|
|
|
|
|
DEFAULT_LANG_MAP = {
|
|
|
|
|
"zh": "zh",
|
|
|
|
@ -93,25 +87,41 @@ class LangSegmenter:
|
|
|
|
|
"en": "en",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
def getTexts(text):
|
|
|
|
|
def getTexts(text,default_lang = ""):
|
|
|
|
|
lang_splitter = LangSplitter(lang_map=LangSegmenter.DEFAULT_LANG_MAP)
|
|
|
|
|
lang_splitter.merge_across_digit = False
|
|
|
|
|
substr = lang_splitter.split_by_lang(text=text)
|
|
|
|
|
|
|
|
|
|
lang_list: list[dict] = []
|
|
|
|
|
|
|
|
|
|
have_num = False
|
|
|
|
|
|
|
|
|
|
for _, item in enumerate(substr):
|
|
|
|
|
dict_item = {"lang": item.lang, "text": item.text}
|
|
|
|
|
dict_item = {'lang':item.lang,'text':item.text}
|
|
|
|
|
|
|
|
|
|
if dict_item['lang'] == 'digit':
|
|
|
|
|
if default_lang != "":
|
|
|
|
|
dict_item['lang'] = default_lang
|
|
|
|
|
else:
|
|
|
|
|
have_num = True
|
|
|
|
|
lang_list = merge_lang(lang_list,dict_item)
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
# 处理短英文被识别为其他语言的问题
|
|
|
|
|
if full_en(dict_item["text"]):
|
|
|
|
|
dict_item["lang"] = "en"
|
|
|
|
|
if full_en(dict_item['text']):
|
|
|
|
|
dict_item['lang'] = 'en'
|
|
|
|
|
lang_list = merge_lang(lang_list,dict_item)
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
if default_lang != "":
|
|
|
|
|
dict_item['lang'] = default_lang
|
|
|
|
|
lang_list = merge_lang(lang_list,dict_item)
|
|
|
|
|
continue
|
|
|
|
|
else:
|
|
|
|
|
# 处理非日语夹日文的问题(不包含CJK)
|
|
|
|
|
ja_list: list[dict] = []
|
|
|
|
|
if dict_item["lang"] != "ja":
|
|
|
|
|
ja_list = split_jako("ja", dict_item)
|
|
|
|
|
if dict_item['lang'] != 'ja':
|
|
|
|
|
ja_list = split_jako('ja',dict_item)
|
|
|
|
|
|
|
|
|
|
if not ja_list:
|
|
|
|
|
ja_list.append(dict_item)
|
|
|
|
@ -120,8 +130,8 @@ class LangSegmenter:
|
|
|
|
|
ko_list: list[dict] = []
|
|
|
|
|
temp_list: list[dict] = []
|
|
|
|
|
for _, ko_item in enumerate(ja_list):
|
|
|
|
|
if ko_item["lang"] != "ko":
|
|
|
|
|
ko_list = split_jako("ko", ko_item)
|
|
|
|
|
if ko_item["lang"] != 'ko':
|
|
|
|
|
ko_list = split_jako('ko',ko_item)
|
|
|
|
|
|
|
|
|
|
if ko_list:
|
|
|
|
|
temp_list.extend(ko_list)
|
|
|
|
@ -131,10 +141,10 @@ class LangSegmenter:
|
|
|
|
|
# 未存在非日韩文夹日韩文
|
|
|
|
|
if len(temp_list) == 1:
|
|
|
|
|
# 未知语言检查是否为CJK
|
|
|
|
|
if dict_item["lang"] == "x":
|
|
|
|
|
cjk_text = full_cjk(dict_item["text"])
|
|
|
|
|
if dict_item['lang'] == 'x':
|
|
|
|
|
cjk_text = full_cjk(dict_item['text'])
|
|
|
|
|
if cjk_text:
|
|
|
|
|
dict_item = {"lang": "zh", "text": cjk_text}
|
|
|
|
|
dict_item = {'lang':'zh','text':cjk_text}
|
|
|
|
|
lang_list = merge_lang(lang_list,dict_item)
|
|
|
|
|
else:
|
|
|
|
|
lang_list = merge_lang(lang_list,dict_item)
|
|
|
|
@ -146,26 +156,57 @@ class LangSegmenter:
|
|
|
|
|
# 存在非日韩文夹日韩文
|
|
|
|
|
for _, temp_item in enumerate(temp_list):
|
|
|
|
|
# 未知语言检查是否为CJK
|
|
|
|
|
if temp_item["lang"] == "x":
|
|
|
|
|
cjk_text = full_cjk(dict_item["text"])
|
|
|
|
|
if temp_item['lang'] == 'x':
|
|
|
|
|
cjk_text = full_cjk(temp_item['text'])
|
|
|
|
|
if cjk_text:
|
|
|
|
|
dict_item = {"lang": "zh", "text": cjk_text}
|
|
|
|
|
lang_list = merge_lang(lang_list, dict_item)
|
|
|
|
|
lang_list = merge_lang(lang_list,{'lang':'zh','text':cjk_text})
|
|
|
|
|
else:
|
|
|
|
|
lang_list = merge_lang(lang_list, dict_item)
|
|
|
|
|
lang_list = merge_lang(lang_list,temp_item)
|
|
|
|
|
else:
|
|
|
|
|
lang_list = merge_lang(lang_list,temp_item)
|
|
|
|
|
|
|
|
|
|
# 有数字
|
|
|
|
|
if have_num:
|
|
|
|
|
temp_list = lang_list
|
|
|
|
|
lang_list = []
|
|
|
|
|
for i, temp_item in enumerate(temp_list):
|
|
|
|
|
if temp_item['lang'] == 'digit':
|
|
|
|
|
if default_lang:
|
|
|
|
|
temp_item['lang'] = default_lang
|
|
|
|
|
elif lang_list and i == len(temp_list) - 1:
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
elif not lang_list and i < len(temp_list) - 1:
|
|
|
|
|
temp_item['lang'] = temp_list[1]['lang']
|
|
|
|
|
elif lang_list and i < len(temp_list) - 1:
|
|
|
|
|
if lang_list[-1]['lang'] == temp_list[i + 1]['lang']:
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
elif lang_list[-1]['text'][-1] in [",",".","!","?",",","。","!","?"]:
|
|
|
|
|
temp_item['lang'] = temp_list[i + 1]['lang']
|
|
|
|
|
elif temp_list[i + 1]['text'][0] in [",",".","!","?",",","。","!","?"]:
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
elif temp_item['text'][-1] in ["。","."]:
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
elif len(lang_list[-1]['text']) >= len(temp_list[i + 1]['text']):
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
else:
|
|
|
|
|
temp_item['lang'] = temp_list[i + 1]['lang']
|
|
|
|
|
else:
|
|
|
|
|
temp_item['lang'] = 'zh'
|
|
|
|
|
|
|
|
|
|
lang_list = merge_lang(lang_list,temp_item)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 筛X
|
|
|
|
|
temp_list = lang_list
|
|
|
|
|
lang_list = []
|
|
|
|
|
for _, temp_item in enumerate(temp_list):
|
|
|
|
|
if temp_item["lang"] == "x":
|
|
|
|
|
if temp_item['lang'] == 'x':
|
|
|
|
|
if lang_list:
|
|
|
|
|
temp_item["lang"] = lang_list[-1]["lang"]
|
|
|
|
|
temp_item['lang'] = lang_list[-1]['lang']
|
|
|
|
|
elif len(temp_list) > 1:
|
|
|
|
|
temp_item["lang"] = temp_list[1]["lang"]
|
|
|
|
|
temp_item['lang'] = temp_list[1]['lang']
|
|
|
|
|
else:
|
|
|
|
|
temp_item["lang"] = "zh"
|
|
|
|
|
temp_item['lang'] = 'zh'
|
|
|
|
|
|
|
|
|
|
lang_list = merge_lang(lang_list,temp_item)
|
|
|
|
|
|
|
|
|
@ -178,3 +219,7 @@ if __name__ == "__main__":
|
|
|
|
|
|
|
|
|
|
text = "ねえ、知ってる?最近、僕は天文学を勉強してるんだ。君の瞳が星空みたいにキラキラしてるからさ。"
|
|
|
|
|
print(LangSegmenter.getTexts(text))
|
|
|
|
|
|
|
|
|
|
text = "当时ThinkPad T60刚刚发布,一同推出的还有一款名为Advanced Dock的扩展坞配件。这款扩展坞通过连接T60底部的插槽,扩展出包括PCIe在内的一大堆接口,并且自带电源,让T60可以安装桌面显卡来提升性能。"
|
|
|
|
|
print(LangSegmenter.getTexts(text,"zh"))
|
|
|
|
|
print(LangSegmenter.getTexts(text))
|