annotate unicode-histogram.py @ 62:c82a8743fd48

taking notes on how to merge
author Henry S. Thompson <ht@inf.ed.ac.uk>
date Thu, 14 Dec 2023 00:13:19 +0000
parents 91d71e9760e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
1 #!/usr/bin/env python
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
2 # -*- coding: utf-8 -*-
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
3 # from https://github.com/usc-isi-i2/dig-unicode/blob/master/python/unicode-histogram.py
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
4 import sys
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
5 import re
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
6 try:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
7 import simplejson as json
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
8 except:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
9 import json
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
10
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
11 from collections import Counter
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
12 import unicodedata
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
13
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
14 from time import strftime, gmtime
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
15
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
16 """
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
17 12 December 2014
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
18 for each of {body, title}:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
19 the unicodeSignature is the sequence of >ascii codepoints, in order, space-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
20 the unicodeCatalog is the bag of >ascii codepoints, sorted/agglomerated using space, comma-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
21 the unicodeHistogram is a json-encoded python dict/json object mapping codepoint to count
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
22
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
23 the unicodeBlockSignature is the sequence of block descriptors (of all >ascii), in order, space-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
24 the unicodeBlockCatalog is the bag of block descriptors, sorted/agglomerated using space, comma-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
25 the unicodeBlockHistogram is a json-encoded python dict/json object mapping block descriptor to count
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
26
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
27 the unicodeCategorySignature is the sequence of category descriptors (of all >ascii), in order, space-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
28 the unicodeCategoryCatalog is the bag of category descriptors, sorted/agglomerated using space, comma-separated
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
29 the unicodeCategoryHistogram is a json-encoded python dict/json object mapping category descriptor to count
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
30
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
31 where block and category descriptors are defined via
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
32 # From http://stackoverflow.com/a/245072
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
33 # retrieved from http://unicode.org/Public/UNIDATA/Blocks.txt
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
34 # Blocks-5.1.0.txt
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
35 # Date: 2008-03-20, 17:41:00 PDT [KW]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
36 and is formatted to using _ rather than ,/space/-
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
37 """
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
38
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
39 def isAscii(c):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
40 try:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
41 return ord(c) <= 127
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
42 except:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
43 return False
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
44
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
45 def gentime():
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
46 return strftime("%Y-%m-%d %H:%M:%S", gmtime())
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
47
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
48 def fmtCodepoint(codepoint, style):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
49 return codepoint
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
50
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
51 def fmtMetadatum(metadatum, style):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
52 def fmtValue(s):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
53 return re.sub("[ -]", "_", re.sub(",", "", unicode(s)))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
54
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
55 if style=="category":
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
56 category = categoryCodeDescription(unicodedata.category(metadatum))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
57 # return "category:" + fmtValue(category)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
58 return fmtValue(category)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
59 elif style=="block":
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
60 # return "block:" + fmtValue(block(metadatum))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
61 return fmtValue(block(metadatum))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
62 else:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
63 return None
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
64
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
65 # From http://stackoverflow.com/a/245072
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
66
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
67 _blocks = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
68
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
69 def _initBlocks(text):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
70 pattern = re.compile(r'([0-9A-F]+)\.\.([0-9A-F]+);\ (\S.*\S)')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
71 for line in text.splitlines():
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
72 m = pattern.match(line)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
73 if m:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
74 start, end, name = m.groups()
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
75 _blocks.append((int(start, 16), int(end, 16), name))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
76
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
77 # retrieved from http://unicode.org/Public/UNIDATA/Blocks.txt
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
78 _initBlocks('''
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
79 # Blocks-5.1.0.txt
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
80 # Date: 2008-03-20, 17:41:00 PDT [KW]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
81 #
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
82 # Unicode Character Database
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
83 # Copyright (c) 1991-2008 Unicode, Inc.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
84 # For terms of use, see http://www.unicode.org/terms_of_use.html
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
85 # For documentation, see UCD.html
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
86 #
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
87 # Note: The casing of block names is not normative.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
88 # For example, "Basic Latin" and "BASIC LATIN" are equivalent.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
89 #
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
90 # Format:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
91 # Start Code..End Code; Block Name
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
92
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
93 # ================================================
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
94
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
95 # Note: When comparing block names, casing, whitespace, hyphens,
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
96 # and underbars are ignored.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
97 # For example, "Latin Extended-A" and "latin extended a" are equivalent.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
98 # For more information on the comparison of property values,
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
99 # see UCD.html.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
100 #
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
101 # All code points not explicitly listed for Block
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
102 # have the value No_Block.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
103
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
104 # Property: Block
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
105 #
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
106 # @missing: 0000..10FFFF; No_Block
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
107
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
108 0000..007F; Basic Latin
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
109 0080..00FF; Latin-1 Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
110 0100..017F; Latin Extended-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
111 0180..024F; Latin Extended-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
112 0250..02AF; IPA Extensions
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
113 02B0..02FF; Spacing Modifier Letters
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
114 0300..036F; Combining Diacritical Marks
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
115 0370..03FF; Greek and Coptic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
116 0400..04FF; Cyrillic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
117 0500..052F; Cyrillic Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
118 0530..058F; Armenian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
119 0590..05FF; Hebrew
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
120 0600..06FF; Arabic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
121 0700..074F; Syriac
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
122 0750..077F; Arabic Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
123 0780..07BF; Thaana
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
124 07C0..07FF; NKo
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
125 0900..097F; Devanagari
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
126 0980..09FF; Bengali
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
127 0A00..0A7F; Gurmukhi
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
128 0A80..0AFF; Gujarati
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
129 0B00..0B7F; Oriya
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
130 0B80..0BFF; Tamil
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
131 0C00..0C7F; Telugu
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
132 0C80..0CFF; Kannada
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
133 0D00..0D7F; Malayalam
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
134 0D80..0DFF; Sinhala
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
135 0E00..0E7F; Thai
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
136 0E80..0EFF; Lao
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
137 0F00..0FFF; Tibetan
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
138 1000..109F; Myanmar
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
139 10A0..10FF; Georgian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
140 1100..11FF; Hangul Jamo
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
141 1200..137F; Ethiopic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
142 1380..139F; Ethiopic Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
143 13A0..13FF; Cherokee
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
144 1400..167F; Unified Canadian Aboriginal Syllabics
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
145 1680..169F; Ogham
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
146 16A0..16FF; Runic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
147 1700..171F; Tagalog
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
148 1720..173F; Hanunoo
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
149 1740..175F; Buhid
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
150 1760..177F; Tagbanwa
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
151 1780..17FF; Khmer
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
152 1800..18AF; Mongolian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
153 1900..194F; Limbu
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
154 1950..197F; Tai Le
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
155 1980..19DF; New Tai Lue
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
156 19E0..19FF; Khmer Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
157 1A00..1A1F; Buginese
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
158 1B00..1B7F; Balinese
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
159 1B80..1BBF; Sundanese
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
160 1C00..1C4F; Lepcha
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
161 1C50..1C7F; Ol Chiki
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
162 1D00..1D7F; Phonetic Extensions
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
163 1D80..1DBF; Phonetic Extensions Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
164 1DC0..1DFF; Combining Diacritical Marks Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
165 1E00..1EFF; Latin Extended Additional
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
166 1F00..1FFF; Greek Extended
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
167 2000..206F; General Punctuation
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
168 2070..209F; Superscripts and Subscripts
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
169 20A0..20CF; Currency Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
170 20D0..20FF; Combining Diacritical Marks for Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
171 2100..214F; Letterlike Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
172 2150..218F; Number Forms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
173 2190..21FF; Arrows
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
174 2200..22FF; Mathematical Operators
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
175 2300..23FF; Miscellaneous Technical
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
176 2400..243F; Control Pictures
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
177 2440..245F; Optical Character Recognition
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
178 2460..24FF; Enclosed Alphanumerics
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
179 2500..257F; Box Drawing
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
180 2580..259F; Block Elements
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
181 25A0..25FF; Geometric Shapes
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
182 2600..26FF; Miscellaneous Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
183 2700..27BF; Dingbats
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
184 27C0..27EF; Miscellaneous Mathematical Symbols-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
185 27F0..27FF; Supplemental Arrows-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
186 2800..28FF; Braille Patterns
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
187 2900..297F; Supplemental Arrows-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
188 2980..29FF; Miscellaneous Mathematical Symbols-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
189 2A00..2AFF; Supplemental Mathematical Operators
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
190 2B00..2BFF; Miscellaneous Symbols and Arrows
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
191 2C00..2C5F; Glagolitic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
192 2C60..2C7F; Latin Extended-C
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
193 2C80..2CFF; Coptic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
194 2D00..2D2F; Georgian Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
195 2D30..2D7F; Tifinagh
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
196 2D80..2DDF; Ethiopic Extended
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
197 2DE0..2DFF; Cyrillic Extended-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
198 2E00..2E7F; Supplemental Punctuation
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
199 2E80..2EFF; CJK Radicals Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
200 2F00..2FDF; Kangxi Radicals
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
201 2FF0..2FFF; Ideographic Description Characters
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
202 3000..303F; CJK Symbols and Punctuation
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
203 3040..309F; Hiragana
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
204 30A0..30FF; Katakana
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
205 3100..312F; Bopomofo
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
206 3130..318F; Hangul Compatibility Jamo
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
207 3190..319F; Kanbun
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
208 31A0..31BF; Bopomofo Extended
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
209 31C0..31EF; CJK Strokes
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
210 31F0..31FF; Katakana Phonetic Extensions
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
211 3200..32FF; Enclosed CJK Letters and Months
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
212 3300..33FF; CJK Compatibility
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
213 3400..4DBF; CJK Unified Ideographs Extension A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
214 4DC0..4DFF; Yijing Hexagram Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
215 4E00..9FFF; CJK Unified Ideographs
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
216 A000..A48F; Yi Syllables
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
217 A490..A4CF; Yi Radicals
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
218 A500..A63F; Vai
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
219 A640..A69F; Cyrillic Extended-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
220 A700..A71F; Modifier Tone Letters
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
221 A720..A7FF; Latin Extended-D
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
222 A800..A82F; Syloti Nagri
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
223 A840..A87F; Phags-pa
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
224 A880..A8DF; Saurashtra
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
225 A900..A92F; Kayah Li
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
226 A930..A95F; Rejang
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
227 AA00..AA5F; Cham
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
228 AC00..D7AF; Hangul Syllables
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
229 D800..DB7F; High Surrogates
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
230 DB80..DBFF; High Private Use Surrogates
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
231 DC00..DFFF; Low Surrogates
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
232 E000..F8FF; Private Use Area
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
233 F900..FAFF; CJK Compatibility Ideographs
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
234 FB00..FB4F; Alphabetic Presentation Forms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
235 FB50..FDFF; Arabic Presentation Forms-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
236 FE00..FE0F; Variation Selectors
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
237 FE10..FE1F; Vertical Forms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
238 FE20..FE2F; Combining Half Marks
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
239 FE30..FE4F; CJK Compatibility Forms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
240 FE50..FE6F; Small Form Variants
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
241 FE70..FEFF; Arabic Presentation Forms-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
242 FF00..FFEF; Halfwidth and Fullwidth Forms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
243 FFF0..FFFF; Specials
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
244 10000..1007F; Linear B Syllabary
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
245 10080..100FF; Linear B Ideograms
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
246 10100..1013F; Aegean Numbers
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
247 10140..1018F; Ancient Greek Numbers
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
248 10190..101CF; Ancient Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
249 101D0..101FF; Phaistos Disc
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
250 10280..1029F; Lycian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
251 102A0..102DF; Carian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
252 10300..1032F; Old Italic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
253 10330..1034F; Gothic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
254 10380..1039F; Ugaritic
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
255 103A0..103DF; Old Persian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
256 10400..1044F; Deseret
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
257 10450..1047F; Shavian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
258 10480..104AF; Osmanya
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
259 10800..1083F; Cypriot Syllabary
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
260 10900..1091F; Phoenician
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
261 10920..1093F; Lydian
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
262 10A00..10A5F; Kharoshthi
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
263 12000..123FF; Cuneiform
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
264 12400..1247F; Cuneiform Numbers and Punctuation
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
265 1D000..1D0FF; Byzantine Musical Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
266 1D100..1D1FF; Musical Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
267 1D200..1D24F; Ancient Greek Musical Notation
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
268 1D300..1D35F; Tai Xuan Jing Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
269 1D360..1D37F; Counting Rod Numerals
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
270 1D400..1D7FF; Mathematical Alphanumeric Symbols
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
271 1F000..1F02F; Mahjong Tiles
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
272 1F030..1F09F; Domino Tiles
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
273 20000..2A6DF; CJK Unified Ideographs Extension B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
274 2F800..2FA1F; CJK Compatibility Ideographs Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
275 E0000..E007F; Tags
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
276 E0100..E01EF; Variation Selectors Supplement
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
277 F0000..FFFFF; Supplementary Private Use Area-A
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
278 100000..10FFFF; Supplementary Private Use Area-B
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
279
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
280 # EOF
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
281 ''')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
282
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
283 def block(ch):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
284 '''
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
285 Return the Unicode block name for ch, or None if ch has no block.
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
286
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
287 >>> block(u'a')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
288 'Basic Latin'
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
289 >>> block(unichr(0x0b80))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
290 'Tamil'
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
291 >>> block(unichr(0xe0080))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
292
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
293 '''
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
294
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
295 assert isinstance(ch, unicode) and len(ch) == 1, repr(ch)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
296 cp = ord(ch)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
297 for start, end, name in _blocks:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
298 if start <= cp <= end:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
299 return name
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
300
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
301 categoryCodeDescriptions = {'Cc': "Other, Control",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
302 'Cf': "Other, Format",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
303 # 'Cn': "Other, Not Assigned (no characters in the file have this property)",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
304 'Cn': "Other, Not Assigned",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
305 'Co': "Other, Private Use",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
306 'Cs': "Other, Surrogate",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
307 'LC': "Letter, Cased",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
308 'Ll': "Letter, Lowercase",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
309 'Lm': "Letter, Modifier",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
310 'Lo': "Letter, Other",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
311 'Lt': "Letter, Titlecase",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
312 'Lu': "Letter, Uppercase",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
313 'Mc': "Mark, Spacing Combining",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
314 'Me': "Mark, Enclosing",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
315 'Mn': "Mark, Nonspacing",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
316 'Nd': "Number, Decimal Digit",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
317 'Nl': "Number, Letter",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
318 'No': "Number, Other",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
319 'Pc': "Punctuation, Connector",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
320 'Pd': "Punctuation, Dash",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
321 'Pe': "Punctuation, Close",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
322 # 'Pf': "Punctuation, Final quote (may behave like Ps or Pe depending on usage)",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
323 # 'Pi': "Punctuation, Initial quote (may behave like Ps or Pe depending on usage)",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
324 'Pf': "Punctuation, Final quote",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
325 'Pi': "Punctuation, Initial quote",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
326 'Po': "Punctuation, Other",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
327 'Ps': "Punctuation, Open",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
328 'Sc': "Symbol, Currency",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
329 'Sk': "Symbol, Modifier",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
330 'Sm': "Symbol, Math",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
331 'So': "Symbol, Other",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
332 'Zl': "Separator, Line",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
333 'Zp': "Separator, Paragraph",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
334 'Zs': "Separator, Space"}
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
335
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
336 def categoryCodeDescription(category):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
337 return categoryCodeDescriptions.get(category, "Not Available")
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
338
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
339 def analyze(part):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
340 content = part["text"]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
341 codepointSeq = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
342 categorySeq = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
343 blockSeq = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
344 codepointHisto = Counter()
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
345 categoryHisto = Counter()
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
346 blockHisto = Counter()
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
347 for c in content:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
348 if not isAscii(c):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
349 codepointHisto[c] += 1
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
350 codepointSeq.append(c)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
351 cat = fmtMetadatum(c, 'category')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
352 blk = fmtMetadatum(c, 'block')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
353 if cat:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
354 categoryHisto[cat] += 1
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
355 categorySeq.append(cat)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
356 if blk:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
357 blockHisto[blk] += 1
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
358 blockSeq.append(blk)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
359 # Normal form KD
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
360 # presumed of minor importance: omitted for now
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
361 # categoryHisto["normalized:" + unicodedata.normalize(c.decode('utf-8'),'NFKD')] += 1
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
362 contentElements = codepointSeq
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
363 # Histogram: JSON-encoded string repn of the dict
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
364 part["unicodeHistogram"] = json.dumps(codepointHisto)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
365 # Signature: sequence of codepoints
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
366 part["unicodeSignature"] = " ".join(codepointSeq)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
367 # Catalog: bag of codepoints
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
368 codepointCatalogElements = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
369 for k in sorted(codepointHisto.keys()):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
370 v = codepointHisto[k]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
371 # v copies of this key
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
372 codepointCatalogElements.append(" ".join([k for _ in xrange(v)]))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
373 part["unicodeCatalog"] = ", ".join(codepointCatalogElements)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
374
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
375 # Histogram: JSON-encoded string repn of the dict
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
376 part["unicodeCategoryHistogram"] = json.dumps(categoryHisto)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
377 # Signature: sequence of codepoints
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
378 part["unicodeCategorySignature"] = " ".join(categorySeq)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
379 # Catalog: bag of categories
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
380 categoryCatalogElements = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
381 for k in sorted(categoryHisto.keys()):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
382 v = categoryHisto[k]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
383 # v copies of this key
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
384 categoryCatalogElements.append(" ".join([k for _ in xrange(v)]))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
385 part["unicodeCategoryCatalog"] = ", ".join(categoryCatalogElements)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
386
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
387 # Histogram: JSON-encoded string repn of the dict
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
388 part["unicodeBlockHistogram"] = json.dumps(blockHisto)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
389 # Signature: sequence of codepoints
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
390 part["unicodeBlockSignature"] = " ".join(blockSeq)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
391 # Catalog: bag of blocks
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
392 blockCatalogElements = []
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
393 for k in sorted(blockHisto.keys()):
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
394 v = blockHisto[k]
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
395 # v copies of this key
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
396 blockCatalogElements.append(" ".join([k for _ in xrange(v)]))
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
397 part["unicodeBlockCatalog"] = ", ".join(blockCatalogElements)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
398
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
399 return part
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
400
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
401 #Test data
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
402 # HEART = u'\u2665'
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
403 # SMILY = u'\u263a'
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
404 # TSU = u'\u30C4'
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
405 # LEFT = u'\u27E8'
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
406 # RIGHT = u'\u27E9'
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
407 # EURO = u'\u20AC'
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
408
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
409 # if True:
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
410
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
411 # TESTUNICODE = LEFT + "h" + EURO + "llo " + HEART + HEART + SMILY + TSU + " goodby" + EURO + " " + SMILY + TSU + HEART + HEART + HEART + HEART + RIGHT
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
412
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
413 # print len(TESTUNICODE)
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
414 # print json.dumps(TESTUNICODE)
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
415
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
416 # TESTDOC = {"@context": "http://localhost:8080/publish/JSON/WSP1WS6-select unix_timestamp(a_importtime)*1000 as timestamp, a_* from ads a join sample s on a_id=s_id limit 50-context.json","schema:provider": {"a": "Organization", "uri": "http://memex.zapto.org/data/organization/1"}, "snapshotUri": "http://memex.zapto.org/data/page/850753E7323B188B93E6E28F730F2BFBFB1CE00B/1396493689000/raw","a": "WebPage","dateCreated": "2013-09-24T18:28:00","hasBodyPart": {"text": TESTUNICODE, "a": "WebPageElement"}, "hasTitlePart": {"text": "\u270b\u270b\u270bOnly Best \u270c\u270c\u270c Forget The Rest \u270b\u270b\u270b Outcall Specials TONIGHT \u270c\ud83d\udc8b\ud83d\udc45 Sexy Blonde is UP LATE \ud83d\udc9c\ud83d\udc9b\u270b\u270c - 25", "a": "WebPageElement"}, "uri": "http://memex.zapto.org/data/page/850753E7323B188B93E6E28F730F2BFBFB1CE00B/1396493689000/processed"}
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
417
53
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
418 # analyze(TESTDOC["hasBodyPart"])
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
419 # json.dump(TESTDOC, sys.stdout, indent=4);
91d71e9760e8 forgot what this is about
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 48
diff changeset
420 # exit(0)
48
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
421
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
422 for line in sys.stdin:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
423 try:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
424 (url, jrep) = line.split('\t')
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
425 d = json.loads(jrep)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
426
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
427 analyze(d["hasBodyPart"])
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
428 analyze(d["hasTitlePart"])
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
429 # insert gmtime
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
430 # ensure it doesn't collide with any other gentime
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
431 d["unicodeGentime"] = gentime()
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
432
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
433 print url + "\t",
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
434 json.dump(d, sys.stdout, sort_keys=True)
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
435 print
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
436 except ValueError as e:
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
437 print >> sys.stderr, e
99bfff1538c6 as downloaded, python2.7...
Henry S. Thompson <ht@inf.ed.ac.uk>
parents:
diff changeset
438 pass