删除html格式“>”使用Python csv.reader从文本文件中

时间:2009-10-28 13:30:55

标签: python html regex file csv

我有一个文本文件;用作分隔符。问题是它有一些html文本格式,例如>显然;在这导致问题。 文本文件很大,我没有这些html字符串的列表,也就是有许多不同的例子,例如$amp;。如何使用python删除所有这些内容。 该文件是名称,地址,电话号码和一些其他字段的列表。我正在寻找crap.html.remove(textfile)模块

3 个答案:

答案 0 :(得分:6)

最快的方法可能是在HTMLParser中使用未记录但迄今为止稳定的unescape方法:

import HTMLParser
s= HTMLParser.HTMLParser().unescape(s)

请注意,这必须输出一个Unicode字符串,因此如果您有任何非ASCII字节,则需要先s.decode(encoding)

答案 1 :(得分:3)

查看here中的代码:

import re, htmlentitydefs

##
# Removes HTML or XML character references and entities from a text string.
#
# @param text The HTML (or XML) source text.
# @return The plain text, as a Unicode string, if necessary.

def unescape(text):
    def fixup(m):
        text = m.group(0)
        if text[:2] == "&#":
            # character reference
            try:
                if text[:3] == "&#x":
                    return unichr(int(text[3:-1], 16))
                else:
                    return unichr(int(text[2:-1]))
            except (ValueError, OverflowError):
                pass
        else:
            # named entity
            try:
                text = unichr(htmlentitydefs.name2codepoint[text[1:-1]])
            except KeyError:
                pass
        return text # leave as is
    return re.sub("&#?\w+;", fixup, text)

当然,这只涉及HTML实体。您可能在文本中有其他分号与CSV解析器混乱。但我想你已经知道......

更新:为可能的OverflowError添加了捕获。

答案 2 :(得分:1)

在大多数Unix系统(包括Mac OS X)上,您可以使用以下命令重新编码输入文本文件:

recode html.. file_with_html.txt

这取代了& gt;通过“>”等等。

例如,您可以通过Python的子流程模块调用它。