如何用非重音字符替换clickhouse中数组中的每个单词的每个重音字符?

Posted

技术标签:

【中文标题】如何用非重音字符替换clickhouse中数组中的每个单词的每个重音字符?【英文标题】:How replace each accented characters with non-accented characters foreach word in array in clickhouse? 【发布时间】:2021-09-12 10:10:45 【问题描述】:

我有一系列单词,['camión', 'elástico', 'Árbol'] 和我想用非重音字符替换数组中每个单词的重音字符(['camion', 'elastico', 'A强>rbol'])

我正在搜索一些这样的

SELECT arrayMap(x -> replaceRegexpAll(x, ['á', 'é', 'í', 'ó', 'ú'], ['a', 'e', 'i', 'o', 'u']), ['camión', 'elástico', 'Árbol']) AS word

我想要这个结果:

['camion', 'elastico', 'arbol']

将每个字符的重音替换为无重音,但这不起作用...

解决的任何想法?

谢谢

【问题讨论】:

【参考方案1】:
SELECT arrayMap(x -> arrayStringConcat(
        arrayMap(y -> if((indexOf(['á', 'é', 'í', 'ó', 'ú'],y) as i) = 0, y, ['a', 'e', 'i', 'o', 'u'][i] ), extractAll(x,'.'))),
         ['camión', 'elástico', 'Árbol']) r

┌─r─────────────────────────────┐
│ ['camion','elastico','Árbol'] │
└───────────────────────────────┘

【讨论】:

我会加上大写和完美!!! SELECT arrayMap(x -> arrayStringConcat( arrayMap(y -> if((indexOf(['Á','á', 'é', 'í', 'ó', 'ú'],y) as i) = 0, y, ['a','a', 'e', 'i', 'o', 'u'][i] ), extractAll(x,'.'))), ['camión', 'elástico', 'Árbol']) r 谢谢丹尼!

以上是关于如何用非重音字符替换clickhouse中数组中的每个单词的每个重音字符?的主要内容,如果未能解决你的问题,请参考以下文章

在 Ruby 中,如何用可能的多个元素替换数组中的元素?

如何用另一个数组值替换javascript中的数组值?

用普通的ascii字符替换重音字符[重复]

如何用 0 替换 varchar 列中的所有非数字值

如何用相同的值替换双精度数组中的所有项目[重复]

如何用零替换数组中的所有负数[重复]