我有一个方法,它使用Beautifulsoup从html文件中的标签返回文本列表。 当我调用方法时,我将方法返回的值保存到变量中。 我认为是一个字符串变量 我第二次调用该方法,并将返回的值存储到另一个字符串变量中。 我想连接这两个字符串,以便我可以在换行符上打印每个字符串。然后,我可以将其添加到我的电子邮件例程中,以便将值打印到电子邮件中。
我收到错误:
Traceback (most recent call last):
File "E:/test_runners/selenium_regression_test_5_1_1/ClearCore - Regression Test/Email/email_selenium_report.py", line 43, in <module>
print rows_part1 + "/n" + rows_part2
TypeError: can only concatenate list (not "str") to list
我的方法实现是:
def extract_data_from_report3(filename):
html_report_part = open(filename,'r')
soup = BeautifulSoup(html_report_part, "html.parser")
th = soup.find_all('th')
td = soup.find_all('td')
headers = [header.get_text(strip=True) for header in soup.find_all("th")]
rows = [dict(zip(headers, [td.get_text(strip=True) for td in row.find_all("td")]))
for row in soup.find_all("tr")[1:-1]]
print(rows)
return rows
调用方法如下:
rows_part1 = report.extract_data_from_report3(r"E:\test_runners\selenium_regression_test_5_1_1\TestReport\SeleniumTestReport_part1.html")
print "part1 = "
print rows_part1
rows_part2 = report.extract_data_from_report3(r"E:\test_runners\selenium_regression_test_5_1_1\TestReport\SeleniumTestReport_part2.html")
print "part2 = "
print rows_part2
print rows_part1 + "/n" + rows_part2
rows_part1中的值为:
part1 =
[{u'Success': u'219', u'Skip': u'0', u'Error': u'9', u'Fail': u'1', u'Total': u'229', u'Class': u'Regression_TestCase.RegressionProject_TestCase2.RegressionProject_TestCase2'}]
rows_part2中的值为:
part2 =
[{u'Success': u'21', u'Skip': u'0', u'Error': u'10', u'Fail': u'5', u'Total': u'230', u'Class': u'Regression_TestCase.RegressionProject_TestCase2.RegressionProject_TestCase2'}]
我想打印出rows_part 1的值,然后在换行符上打印出rows_part2的值。 我正在连接它,所以我可以将一个变量放在电子邮件消息正文中,这将打印出值。
或者我如何从列表中提取内容并将其附加到字符串变量? 然后我可以打印出字符串变量。
谢谢, 里亚兹
答案 0 :(得分:4)
首先,在Python中,您不必声明变量类型,它是在引擎盖下分配的。这让你对变量类型感到困惑。
返回一个列表
[...]
我认为是一个字符串变量
您的print语句正在尝试打印list
类型对象,然后是新行,然后是另一个list
类型对象。您的问题来自&#34; \ n&#34;之间。
可以使用str1 + str2
可以使用list1.append(list2)
但是将字符串连接到列表(或将列表连接到字符串)不是!您需要做的是将列表对象转换为字符串(该列表)。
print str(rows_part1) + "/n" + str(rows_part2)
应该有用。