跳转到主内容
跳转到主内容

自然语言处理(NLP)函数

Experimental feature. Learn more.
Not supported in ClickHouse Cloud
注意

这是仍在开发中的实验性功能,尚未准备好广泛使用。在未来的版本中,它可能会以不可预测且向后不兼容的方式发生变化。请将 allow_experimental_nlp_functions 设置为 1 以启用该功能。

detectCharset

自 v22.2.0 起引入

检测非 UTF-8 编码输入字符串的字符集。

语法

detectCharset(s)

参数

  • s — 要分析的文本。String

返回值

返回一个字符串,包含检测到的字符集编码。String

示例

基本用法

SELECT detectCharset('Ich bleibe für ein paar Tage.')
WINDOWS-1252

detectLanguage

引入版本:v22.2.0

检测 UTF-8 编码输入字符串的语言。 该函数使用 CLD2 库 进行检测,并返回由两个字母组成的 ISO 语言代码。

输入越长,语言检测的精度越高。

语法

detectLanguage(s)

参数

  • text_to_be_analyzed — 要分析的文本。String

返回值

返回检测到的语言对应的 2 字母 ISO 代码。其他可能的返回值:un = 未知,无法检测到任何语言;other = 检测到的语言没有 2 字母代码。String

示例

混合语言文本

SELECT detectLanguage('Je pense que je ne parviendrai jamais à parler français comme un natif. Where there\'s a will, there\'s a way.')
fr

detectLanguageMixed

引入自:v22.2.0

detectLanguage 函数类似,但 detectLanguageMixed 返回一个 Map,其键为 2 个字母的语言代码,值为该语言在文本中所占的百分比。

语法

detectLanguageMixed(s)

参数

  • s — 要分析的文本 String

返回值

返回一个 Map,其键为 2 个字母的 ISO 语言代码,对应的值为在该语言中检测到的文本所占百分比 Map(String, Float32)

示例

混合语言

SELECT detectLanguageMixed('二兎を追う者は一兎をも得ず二兎を追う者は一兎をも得ず A vaincre sans peril, on triomphe sans gloire.')
{'ja':0.62,'fr':0.36}

detectLanguageUnknown

引入自:v22.2.0

detectLanguage 函数类似,但 detectLanguageUnknown 函数可处理非 UTF-8 编码的字符串。 当字符集为 UTF-16 或 UTF-32 时,优先使用此版本。

语法

detectLanguageUnknown('s')

参数

  • s — 要分析的文本。String

返回值

返回检测到的语言的 2 个字母的 ISO 代码。其他可能的结果:un = 未知,无法检测出任何语言;other = 检测到的语言没有对应的 2 字母代码。String

示例

基本用法

SELECT detectLanguageUnknown('Ich bleibe für ein paar Tage.')
de

detectProgrammingLanguage

引入版本:v22.2.0

根据给定的源代码片段判断其所使用的编程语言。

语法

detectProgrammingLanguage('source_code')

参数

  • source_code — 要分析的源代码的字符串表示形式。String

返回值

返回表示编程语言的 String

示例

C++ 代码检测

SELECT detectProgrammingLanguage('#include <iostream>')
C++

detectTonality

引入版本:v22.2.0

判断所提供文本数据的情感倾向。

限制

当前形式下此函数存在一定限制:它使用内置情感字典,并且目前仅适用于俄语。

语法

detectTonality(s)

参数

  • s — 要分析的文本。String

返回值

返回文本中各单词的平均情感值。Float32

示例

俄语情感分析

SELECT
    detectTonality('Шарик - хороший пёс'),
    detectTonality('Шарик - пёс'),
    detectTonality('Шарик - плохой пёс')
0.44445, 0, -0.3

lemmatize

引入版本:v21.9.0

对给定单词执行词形还原。 此函数需要字典才能工作,可以从 GitHub 获取。关于从本地文件加载字典的更多信息,请参阅页面 "Defining Dictionaries"

语法

lemmatize(lang, word)

参数

  • lang — 要应用词形还原规则的语言。String
  • word — 需要进行词形还原的小写单词。String

返回值

返回该单词的词形还原形式 String

示例

英语词形还原

SELECT lemmatize('en', 'wolves')
wolf

stem

自 v21.9.0 起引入

对给定单词执行词干提取。

语法

stem(lang, word)

参数

  • lang — 应用规则所依据的语言。使用两个字母的 ISO 639-1 代码。String
  • word — 需要进行词干提取的小写单词。String

返回值

返回该单词的词干形式 String

示例

英文词干提取

SELECT arrayMap(x -> stem('en', x),
['I', 'think', 'it', 'is', 'a', 'blessing', 'in', 'disguise']) AS res
['I','think','it','is','a','bless','in','disguis']

同义词(synonyms)

引入版本:v21.9.0

查找给定单词的同义词。

同义词扩展有两种类型:

  • plain
  • wordnet

对于 plain 扩展类型,你需要提供一个纯文本文件的路径,其中每一行对应一个同义词集合(synonym set)。 该行中的单词必须用空格或制表符分隔。

对于 wordnet 扩展类型,你需要提供一个包含 WordNet 词库(thesaurus)的目录路径。 该词库中必须包含 WordNet sense index。

语法

synonyms(ext_name, word)

参数

  • ext_name — 要在其中进行搜索的扩展。String
  • word — 要在扩展中查找的单词。String

返回值

返回给定单词的同义词数组。Array(String)

示例

查找同义词

SELECT synonyms('list', 'important')
['important','big','critical','crucial']