summaryrefslogtreecommitdiff
path: root/corpus/xml-tok.py
diff options
context:
space:
mode:
authorChris Dyer <redpony@gmail.com>2014-03-13 22:52:24 -0400
committerChris Dyer <redpony@gmail.com>2014-03-13 22:52:24 -0400
commit2ca6c0da1eb8c67be54ae202834980f23ae8eecf (patch)
tree8c5c4c38ea06d46dc6a27fd5321da2a7e2244050 /corpus/xml-tok.py
parent80f465a250e7fcfc5dd476d04e39a43ef0c909a3 (diff)
parentb2b25c9e71a7ae1b20b7350a236419aa37179e7c (diff)
Merge branch 'master' of https://github.com/redpony/cdec
Diffstat (limited to 'corpus/xml-tok.py')
-rwxr-xr-xcorpus/xml-tok.py47
1 files changed, 47 insertions, 0 deletions
diff --git a/corpus/xml-tok.py b/corpus/xml-tok.py
new file mode 100755
index 00000000..4357ced6
--- /dev/null
+++ b/corpus/xml-tok.py
@@ -0,0 +1,47 @@
+#!/usr/bin/env python
+
+import os
+import re
+import subprocess
+import sys
+
+# Tokenize XML files with tokenize-anything.sh
+# in: <seg id="963"> The earnings on its 10-year bonds are 28.45%. </seg>
+# out: <seg id="963"> The earnings on its 10 - year bonds are 28.45 % . </seg>
+
+def escape(s):
+ return s.replace('&', '&amp;').replace('>', '&gt;').replace('<', '&lt;').replace('"', '&quot;').replace('\'', '&apos;')
+
+def unescape(s):
+ return s.replace('&gt;', '>').replace('&lt;', '<').replace('&quot;', '"').replace('&apos;', '\'').replace('&amp;', '&')
+
+def main():
+ tok = subprocess.Popen([os.path.join(os.path.dirname(__file__), 'tokenize-anything.sh'), '-u'], stdin=subprocess.PIPE, stdout=subprocess.PIPE)
+ while True:
+ line = sys.stdin.readline()
+ if not line:
+ break
+ line = line.strip()
+ pieces = []
+ eol = len(line)
+ pos = 0
+ while pos < eol:
+ next = line.find('<', pos)
+ if next == -1:
+ next = eol
+ tok.stdin.write('{}\n'.format(unescape(line[pos:next])))
+ pieces.append(escape(tok.stdout.readline().strip()))
+ if next == eol:
+ break
+ pos = line.find('>', next + 1)
+ if pos == -1:
+ pos = eol
+ else:
+ pos += 1
+ pieces.append(line[next:pos])
+ sys.stdout.write('{}\n'.format(' '.join(pieces).strip()))
+ tok.stdin.close()
+ tok.wait()
+
+if __name__ == '__main__':
+ main()