- HZ (character encoding)
The HZ character encoding is an encoding of
GB2312 that was formerly commonly used in email andUSENET postings. It was designed in 1989 by Fung Fung Lee (李楓峰) of Stanford University, and subsequently codified in 1995 into RFC 1843.The HZ (short for
Hanzi ) encoding was invented to facilitate the use of Chinese characters through e-mail, which at that time only allowed 7-bit characters. Therefore, in lieu of standard ISO 2022 escape sequences (as in the case ofISO-2022-JP ) or 8-bit characters (as in the case ofEUC ), the HZ code uses only printable, 7-bit characters to represent Chinese characters.It was also popular in USENET networks, which in the late 1980s and early 1990s, generally did not allow transmission of 8-bit characters or escape characters.
tructure and use
In the HZ encoding system, the character sequences "~{" and "~}" act as escape sequences; anything between them is interpreted as Chinese encoded in GB2312 (the most significant bits are ignored). Outside the escape sequences, characters are assumed to be
ASCII .An example will help illustrate the relationship between
GB2312 , EUC-CN, and the HZ code:HZ was originally designed to be used purely as a 7-bit code. However, when situations allow, the escape sequences "~{" and "~}" sometimes surround characters represented in EUC-CN; this alternative use allows Chinese to be readable either with the help of HZ decoder software, or with a system that understands EUC-CN.
Additionally, the specification defines that
* the sequence "~~" is to be treated as encoding a single ASCII "~"
* the character "~" followed by a newline is to be discarded.However, not all HZ decoders follow these two rules.HZ decoders
The first HZ decoder was written in 1989 by the code's inventor for the
Unix operating system.The hztty program, also for the
Unix operating system, was also among the first and one of the most popular HZ decoders. It deviates from the specification in that it will display the escape sequences (i.e., "~{" and "~}"), and it does not treat "~~" and "~" followed by a newline specially. This was probably to allow software which assumes one character to occupy one screen position (on a text screen) to function correctly without modification.Support on
Microsoft Windows came later, and a number of third-party "Chinese systems" support HZ. These systems may provide an option to hide the escape sequences.References
* [http://quimby.gnus.org/rfc/rfc1843.txt RFC 1843]
* [http://umunhum.stanford.edu/~lee/chicomp/HZ_spec.html HZ — A Data Format for Exchanging Files of Arbitrarily Mixed Chinese and ASCII Characters] , [http://web.archive.org/web/20051027040810/umunhum.stanford.edu/~lee/chicomp/HZ_spec.html Archived version]
Wikimedia Foundation. 2010.