чтение # char в питоне - PullRequest
       14

чтение # char в питоне

1 голос
/ 12 марта 2011

Может ли кто-нибудь помочь мне с чтением символа "#" в python? я не могу получить файл. поскольку это вывод из стэнфордского постаггера, есть ли сценарии для преобразования файла стэнфордского постаггера http://nlp.stanford.edu/software/tagger.shtml в cwb. http://cogsci.uni -osnabrueck.de / ~ korpora / WS / CWBdoc / CWB_Encoding_Tutorial / node3.html

так что это текстовый файл utf-8, который я пытаюсь прочитать:

 如果#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:

#!/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'

Ответы [ 2 ]

1 голос
/ 12 марта 2011
if word == '\#':

Это, вероятно, не делает то, что вы думаете, что делает. (Подсказка: print "\#")

1 голос
/ 12 марта 2011

Если Python не распознает escape-последовательность, он включит в строку обратную косую черту.

>>> '\#' == '\\#'
True
...