Python转换HTML到Text纯文本的方法

1146次阅读  |  发布于5年以前

本文实例讲述了Python转换HTML到Text纯文本的方法。分享给大家供大家参考。具体分析如下:

今天项目需要将HTML转换为纯文本,去网上搜了一下,发现Python果然是神通广大,无所不能,方法是五花八门。

拿今天亲自试的两个方法举例,以方便后人:

方法一:

1. 安装nltk,可以去pipy装

(注:需要依赖以下包:numpy, PyYAML)

2.测试代码:

复制代码 代码如下:

import nltk
aa = r'''''

Project: DeHTML
Description:
This small script is intended to allow conversion from HTML markup to plain text. ''' aa '\n\n \n Project: DeHTML
\n Description:
\n This small script is intended to allow conversion from HTML markup to \n plain text.\n \n \n ' print nltk.clean_html(aa) Project: DeHTML Description : This small script is intended to allow conversion from HTML markup to plain text.

方法二:

如果觉得nltk太笨重,大材小用的话,可以自己写代码,代码如下:

复制代码 代码如下:

from HTMLParser import HTMLParser
from re import sub
from sys import stderr
from traceback import print_exc

class _DeHTMLParser(HTMLParser):
def init(self):
HTMLParser.init(self)
self.__text = []

def handle_data(self, data):    
    text = data.strip()    
    if len(text) > 0:    
        text = sub('[ \t\r\n]+', ' ', text)    
        self.__text.append(text + ' ')    

def handle_starttag(self, tag, attrs):    
    if tag == 'p':    
        self.__text.append('\n\n')    
    elif tag == 'br':    
        self.__text.append('\n')    

def handle_startendtag(self, tag, attrs):    
    if tag == 'br':    
        self.__text.append('\n\n')    

def text(self):    
    return ''.join(self.__text).strip()    

def dehtml(text):
try:
parser = _DeHTMLParser()
parser.feed(text)
parser.close()
return parser.text()
except:
print_exc(file=stderr)
return text

def main():
text = r'''''

Project: DeHTML
Description:
This small script is intended to allow conversion from HTML markup to plain text. ''' print(dehtml(text))

if name == 'main':
main()

运行结果:

================================ RESTART ================================

Project: DeHTML
Description :
This small script is intended to allow conversion from HTML markup to plain text.

希望本文所述对大家的Python程序设计有所帮助。

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8