Two seemingly identical unicode strings turn out to be different when using repr(), but how can I fix this?

后端 未结 2 1984
南笙
南笙 2021-01-03 11:25

I have two lists of unicode strings, one containing words picked up from a text file, another containing a list of sound file names from a directory, stripped from their ext

相关标签:
2条回答
  • 2021-01-03 11:52

    The problem seems to be in an ambiguous representation of grave accents in unicode. Here is LATIN SMALL LETTER A WITH GRAVE and here is COMBINING GRAVE ACCENT which when combined with 'a' becomes more or less the exact same character as the first. So two representations of the same character. In fact unicode has a term for this: unicode equivalence.

    To implement this in python, use unicodedata.normalize on the string before comparing. I tried 'NFC' mode which returns u'ch\xe0o' for both strings.

    0 讨论(0)
  • 2021-01-03 11:59

    Some Unicode characters can be specified different ways, as you've discovered, either as a single codepoint or as a regular codepoint plus a combining codepoint. The character \u0300 is a COMBINING GRAVE ACCENT, which adds an accent mark to the preceding character.

    The process of fixing a string to a common representation is called normalization. You can use the unicodedata module to do this:

    def n(str):
        return unicodedata.normalize('NFKC', str)
    
    >>> n(u'ch\xe0o') == n(u'cha\u0300o')
    True
    
    0 讨论(0)
提交回复
热议问题