有人可以帮我在python中读“#”char吗?我似乎无法得到该文件。因为这是stanford postagger的输出,是否有可用于将stanford postagger http://nlp.stanford.edu/software/tagger.shtml文件转换为cwb的脚本。 http://cogsci.uni-osnabrueck.de/~korpora/ws/CWBdoc/CWB_Encoding_Tutorial/node3.html
所以这是我想读的utf-8 txt文件:
如果#CS 您#PN 在#P 新加坡#NR 只#AD 能#VV 前往#VV 一#CD 间#M 俱乐部#NN ,#PU 祖卡#NN 酒吧#NN 必然#AD 是#VC 您#PN 的#DEG 不二#JJ 选择#NN 。#PU
作为#P 或许#AD 是#VC 新加坡#NR 唯一#JJ 一#CD 家#M 国际#NN 知名#VA 的#DEC 夜店#NN ,#PU 祖卡#NN 既#CC 是#VC 一#CD 个#M 公共#JJ 机构#NN ,#PU
所以使用这段代码我不会在utf-8 txt文件中的#con中读到:
#!/usr/bin/python # -*- coding: utf-8 -*-
'''
stanford POS tagger to CWB format
'''
import codecs
import nltk
import os, sys, re, glob
reload(sys)
sys.setdefaultencoding('utf-8')
cwd = './path/to/file.txt' #os.getcwd()
for infile in glob.glob(os.path.join(cwd, 'zouk.txt')):
print infile
(PATH, FILENAME) = os.path.split(infile)
reader = codecs.open(infile, 'r', 'utf-8')
for line in reader:
for word in line:
if word == '\#':
print 'hex is here'
答案 0 :(得分:1)
如果Python无法识别转义序列,那么它将在字符串中包含反斜杠。
>>> '\#' == '\\#'
True
答案 1 :(得分:1)
if word == '\#':
这可能不符合你的想法。 (提示:print "\#"
)