Code 39 (also known as Alpha39, Code 3 of 9, Code 3/9, Type 39, USS Code 39, or USD-3) is a variable length, discrete barcode symbology.
The Code 39 specification defines 43 characters, consisting of uppercase letters (A through Z), numeric digits (0 through 9) and a number of special characters (-, ., $, /, +, %, and space). An additional character (denoted '*') is used for both start and stop delimiters. Each character is composed of nine elements: five bars and four spaces. Three of the nine elements in each character are wide (binary value 1), and six elements are narrow (binary value 0). The width ratio between narrow and wide can be chosen between 1:2 and 1:3.
The barcode itself does not contain a check digit (in contrast to—for instance—Code 128), but it can be considered self-checking on the grounds that a single erroneously interpreted bar cannot generate another valid character. Possibly the most serious drawback of Code 39 is its low data density: It requires more space to encode data in Code 39 than, for example, in Code 128. This means that very small goods cannot be labeled with a Code 39 based barcode. However, Code 39 is still widely used and can be decoded with virtually any barcode reader. One advantage of Code 39 is that since there is no need to generate a check digit, it can easily be integrated into existing printing system by adding a barcode font to the system or printer and then printing the raw data in that font.
Code 39 was developed by Dr. David Allais and Ray Stevens of Intermec in 1974. Their original design included two wide bars and one wide space in each character, resulting in 40 possible characters. Setting aside one of these characters as a start and stop pattern left 39 characters, which was the origin of the name Code 39. Punctuation characters were later added that deviated from this pattern, expanding the character set to 43 characters. Code 39 was later standardised as ANSI MH 10.8 M-1983 and MIL-STD-1189. MIL-STD-1189 has been cancelled and replaced by ANSI/AIM BC1/1995, Uniform Symbology Specification - Code 39.
The * character presented below is not a true encodable character, but is the start and stop symbol for Code 39. The asymmetry of the symbol allows the reader to determine the direction of the barcode being scanned. This code is traditionally mapped to the * character in barcode fonts and will often appear with the human-readable representation alongside the barcode.
As a generality, the location of the two wide bars can be considered to encode a number between 1 and 10, and the location of the wide space (which has four possible positions) can be considered to classify the character into one of four groups (from left to right): Letters+20 (U-Z), Digits, Letters+0 (A-J), and Letters+10 (K-T). For example, the letter P (being the 16th letter of the alphabet) has its bars aligned to represent the number 6, and the space in the far right position to select the group Letters+10.
When represented as a digit, the number "10" is used to encode the number zero. Because there are only six letters in the Letters+20 group (letters 21-26, or U-Z), the other four positions in this group (27-30) are used to represent three symbols (dash, period, space) as well as the start/stop character.
The two wide bars encode a number between 1 and 10 by occupying two of five positions which have the following numeric equivalence: 1, 2, 4, 7, P. The numbers are summed together. For example, the number 6 is encoded NWWNN, with wide bars occupying the positions for 2 and 4 (2+4=6). The P position stands for parity, and does not add anything to the sum - instead, it contains a wide bar only when encoding numbers that need a single bar (1, 2, 4, and 7), so as to ensure that exactly two of the five positions still contain a wide bar.
These tables outline the Code 39 specification:
|W||B||Wide - Black|
|N||b||Narrow - Black|
|w||W||Wide - White|
|n||w||Narrow - White|
(Note, Format1 and Format2 are just two different ways of describing the same underlying encoding, not two variants of Code 39.)
|Char nr for checksum||Char||Format1||Format2|
Please Note: In between each character (the start and stop characters included) there is a thin space (shown as w below). For example, if you wanted a Code 39 barcode composed of the letter "A", you would need the following to be encoded (using Format 2 as described above): "*A*". [bWbwBwBwb]w[BwbwbWbwB]w[bWbwBwBwb]
The code will not be read without these spaces. Barcode fonts invariably include this space within the glyph for the character.
Code 39 mod 43
Here is how to do the checksum calculation:
- Take the value (0 through 42) of each character in the barcode excluding start and stop codes.
- Sum the values.
- Divide the result by 43.
- The remainder is the value of the checksum character to be appended.
Full ASCII Code 39
Code 39 is restricted to 43 characters. In Full ASCII Code 39 Symbols 0-9, A-Z, ".", and "-" are the same as their representations in Code 39. Lower case letters, additional punctuation characters and control characters are represented by sequences of two characters of Code 39.
|31||US||%E||63||?||%J||95||_||%O||127||DEL||%T, %X, %Y, %Z|
- Allais, D. C. (2006). AIDC Memoirs (PDF).
- "MIL-STD-1189 Standard Department of Defense Barcode Symbology". 1989-08-10. Retrieved 2010-07-22.
- "Adoption Notice: AIM/BC1 Uniform Symbology Specification". 1997-06-19. Archived from the original on 23 Aug 2012. Retrieved 2011-04-06.