【发布时间】:2016-07-07 19:45:01
【问题描述】:
我尝试使用 BeautifulSoup 编写程序以向 (http://upodn.com/phon.php) 提交任何单词,然后打印结果。
例如,当我向 (http://upodn.com/phon.php) 网站提交“hello”字样时,结果是:həlo
但是当我使用我的脚本提交“你好”这个词时,结果是:həlo
我如何打印网站上出现的结果 => həlo ?
脚本:
# -*- coding: utf-8 -*-
import mechanize
import cookielib
from BeautifulSoup import BeautifulSoup
import html2text
br = mechanize.Browser()
cj = cookielib.LWPCookieJar()
br.set_cookiejar(cj)
br.set_handle_equiv(True)
br.set_handle_redirect(True)
br.set_handle_referer(True)
br.set_handle_robots(False)
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)
br.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1'), ('Content-type', 'text/html; charset=utf-8')]
br.open('http://upodn.com/phon.php')
br.select_form(nr=0)
br.form['intext'] = 'hello'
br.submit()
data = br.response().read()
soup = BeautifulSoup(data)
# print soup
table = soup.find('table', {'rules': 'cols'})
result = []
for row in table.findAll("font"):
d = row.text
result.append(d)
print result[1]
输出:
həlo
[Finished in 2.7s]
【问题讨论】:
-
首先,您使用的是过时版本的 BeautifulSoup;当前版本是包和模块
bs4
标签: python python-2.7 unicode beautifulsoup mechanize