stri_trans_nf: Perform or Check For Unicode Normalization

Description Usage Arguments Details Value References See Also Examples

Description

These functions convert strings to NFC, NFKC, NFD, NFKD, or NFKC_Casefold Unicode Normalization Form or check whether strings are normalized.

Usage

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19

Arguments

str

character vector to be encoded

Details

Unicode Normalization Forms are formally defined normalizations of Unicode strings which, e.g., make possible to determine whether any two strings are equivalent. Essentially, the Unicode Normalization Algorithm puts all combining marks in a specified order, and uses rules for decomposition and composition to transform each string into one of the Unicode Normalization Forms.

The following Normalization Forms (NFs) are supported:

Note that many W3C Specifications recommend using NFC for all content, because this form avoids potential interoperability problems arising from the use of canonically equivalent, yet different, character sequences in document formats on the Web. Thus, you will rather not use these functions in typical string processing activities. Most often you may assume that a string is in NFC, see RFC\#5198.

As usual in stringi, if the input character vector is in the native encoding, it will be automatically converted to UTF-8.

For more general text transforms refer to stri_trans_general.

Value

The stri_trans_nf* functions return a character vector of the same length as input (the output is always in UTF-8).

stri_trans_isnf* return a logical vector.

References

Unicode Normalization Forms – Unicode Standard Annex #15, http://unicode.org/reports/tr15

Unicode Format for Network Interchange – RFC\#5198, http://tools.ietf.org/rfc/rfc5198.txt

Character Model for the World Wide Web 1.0: Normalization – W3C Working Draft, http://www.w3.org/TR/charmod-norm/

Normalization – ICU User Guide, http://userguide.icu-project.org/transforms/normalization (technical details)

Unicode Equivalence – Wikipedia, http://en.wikipedia.org/wiki/Unicode_equivalence

See Also

Other transform: stri_trans_char, stri_trans_general, stri_trans_list, stri_trans_tolower

Examples

1
2
stri_trans_nfd("\u0105") # Polish a with ogonek -> a, ogonek
stri_trans_nfkc("\ufdfa") # 1 codepoint -> 18 codepoints

stringi documentation built on May 2, 2019, 4:21 a.m.