Windows-1252 or CP-1252 (code page 1252) is a single-byte character encoding of the Latin alphabet, used by default in the legacy components of Microsoft Windows for English and many European languages including Spanish, French, and German.
|MIME / IANA||windows-1252|
|Alias(es)||cp1252 (code page 1252)|
|Language(s)||Basically all supported by ISO/IEC 8859-1 e.g. English, Irish, Italian, Norwegian, Danish, Portuguese, Spanish, Swedish, German, Finnish, Icelandic, French, Faroese, Luxembourgish, Albanian, Estonian, Swahili, Tswana, Catalan, Basque, Occitan, Romansh, Dutch (except the Ĳ/ĳ character, substituted by IJ/ÿ), and Slovene (except the č character, substituted by ç).|
|Standard||WHATWG Encoding Standard|
|Classification||extended ASCII, Windows-125x|
|Extends||ISO 8859-1 (excluding C1 controls)|
|Transforms / Encodes||ISO 8859-15|
It is the most-used single-byte character encoding in the world (on websites at least). As of September 2022[update], 0.3% of all websites declared use of Windows-1252, but at the same time 1.3% used ISO 8859-1 (while only 9 of the top 1000 websites), which by HTML5 standards should be considered the same encoding, so that 1.6% of websites effectively use Windows-1252. Pages declared as US-ASCII would also count as this character set. An unknown (but probably large) subset of other pages use only the ASCII portion of UTF-8, or only the codes matching Windows-1252 from their declared character set, and could also be counted.
This character encoding is a superset of ISO 8859-1 in terms of printable characters, but differs from the IANA's ISO-8859-1 by using displayable characters rather than control characters in the 80 to 9F (hex) range. Notable additional characters include curly quotation marks and all the printable characters that are in ISO 8859-15 (at different places than ISO 8859-15). It is known to Windows by the code page number 1252, and by the IANA-approved name "windows-1252".
It is very common to mislabel Windows-1252 text with the charset label ISO-8859-1. A common result was that all the quotes and apostrophes (produced by "smart quotes" in word-processing software) were replaced with question marks or boxes on non-Windows operating systems, making text difficult to read. Most modern web browsers and e-mail clients treat the media type charset ISO-8859-1 as Windows-1252 to accommodate such mislabeling. This is now standard behavior in the HTML5 specification, which requires that documents advertised as ISO-8859-1 actually be parsed with the Windows-1252 encoding.
Historically, the phrase "ANSI Code Page" was used in Windows to refer to non-DOS encodings; the intention was that most of these would be ANSI standards such as ISO-8859-1. Even though Windows-1252 was the first and by far most popular code page named so in Microsoft Windows parlance, the code page has never been an ANSI standard. Microsoft explains, "The term ANSI as used to signify Windows code pages is a historical reference, but is nowadays a misnomer that continues to persist in the Windows community."
In LaTeX packages, CP-1252 is referred to as "ansinew".
The following table shows Windows-1252. Differences from ISO-8859-1 have the Unicode code point number below the character, based on the Unicode.org mapping of Windows-1252 with "best fit". A tooltip, generally available only when one points to the immediate left of the character, shows the Unicode code point name and the decimal Alt code.
According to the information on Microsoft's and the Unicode Consortium's websites, positions 81, 8D, 8F, 90, and 9D are unused; however, the Windows API
MultiByteToWideChar maps these to the corresponding C1 control codes. The "best fit" mapping documents this behavior, too.
- The first version of the codepage 1252 used in Microsoft Windows 1.0 did not have positions D7 and F7 defined. All the characters in the ranges 80–9F were undefined too.
- The second version, used in Microsoft Windows 2.0, positions D7, F7, 91, and 92 had been defined.
- The third version, used since Microsoft Windows 3.1, had all the present-day positions defined, except euro sign and Z with caron character pair.
- The final version listed above debuted in Microsoft Windows 98 and was ported to older versions of Windows with the euro symbol update.
The OS/2 operating system supports an encoding by the name of Code page 1004 (CCSID 1004) or "Windows Extended". This mostly matches code page 1252, with the exception of certain C0 control characters being replaced by diacritic characters.
|Code page 1004 (differing rows only)|
MSDOS extensions [rare]Edit
There is a rarely used, but useful, graphics extended code page 1252 where codes 0x00 to 0x1f allow for box drawing as used in applications such as MSDOS Edit and Codeview. One of the applications to use this code page was an Intel Corporation Install/Recovery disk image utility from mid/late 1995. These programs were written for its P6 User Test Program machines (US example). It was used exclusively in its then EMEA region (Europe, Middle East & Africa). In time the programs were changed to use code page 850.
|Graphics Extended Code Page 1252|
Palm OS variantEdit
|Palm OS code page|
- Character Sets, Internet Assigned Numbers Authority (IANA), 2018-12-12
- "Historical trends in the usage statistics of character encodings for websites, September 2022". w3techs.com. Retrieved 2022-09-19.
- "Frequenty Asked Questions". w3techs.com.
- "Usage Survey of Character Encodings broken down by Ranking". w3techs.com. Retrieved 2022-09-19.
- "Encoding". WHATWG. 27 January 2015. sec. 5.2 Names and labels. Archived from the original on 4 February 2015. Retrieved 4 February 2015.
- "Distribution of Character Encodings among websites that use .de". w3techs.com. Retrieved 2022-09-19.
- "Distribution of Character Encodings among websites that use German". w3techs.com. Retrieved 2022-01-24.
- Wissink, Cathy (5 April 2002). "Unicode and Windows XP" (PDF). Microsoft. p. 1. Archived (PDF) from the original on 4 February 2015. Retrieved 4 February 2015.
- "Code page 1252 information document". Archived from the original on 2016-03-03.
- "CCSID 1252 information document". Archived from the original on 2016-03-26.
- "CCSID 5348 information document". Archived from the original on 2014-11-29.
- "Database Client Installation Guide". Oracle. Retrieved 2021-02-14.
- "Unicode mappings of Windows-1252 with 'Best Fit'". Unicode. Archived from the original on 4 February 2015. Retrieved 4 February 2015.
- Code Page CPGID 01252 (pdf) (PDF), IBM
- Code Page CPGID 01252 (txt), IBM
- International Components for Unicode (ICU), ibm-1252_P100-2000.ucm, 2002-12-03
- International Components for Unicode (ICU), ibm-5348_P100-1997.ucm, 2002-12-03
- "Code page 1004 information document". Archived from the original on 2015-06-25.
- "CCSID 1004 information document". Archived from the original on 2016-03-26.
- "Code Page 01004" (PDF). IBM. Archived from the original (PDF) on 2015-07-08. (version based on Windows 3.1 version of Windows-1252)
- Code Page CPGID 01004 (pdf) (PDF), IBM
- Code Page CPGID 01004 (txt), IBM
- Borgendale, Ken (2001). "Codepage 1004 - Windows Extended". OS/2 codepages by number. Archived from the original on 2018-05-13. Retrieved 2018-05-13. (version based on current version of Windows-1252)
- Storaasli, Olaf (1996). "Performance of the NASA equation solvers on computational mechanics applications" (PDF). Performance of NASA Equation Solvers on Computational Mechanics Applications. NASA. doi:10.2514/6.1996-1505. S2CID 15711051. Archived from the original (PDF) on 2019-05-03.
- "codecs — Codec registry and base classes (§ Text Encodings)". The Python Standard Library—Python 3.9.4 Documentation. Python Software Foundation.
- Mullender, Sjoerd (9 December 2021). "Python Character Mapping Codec for Palm OS 3.5". CPython source tree. Python Software Foundation.