【发布时间】:2011-11-30 07:17:51
【问题描述】:
我正在尝试抓取一个与my previous question 结构非常相似的表here。我刚刚更改了属性名称,但出现index out of range 错误。这是TR:
<TR VALIGN="bottom">
<TD BGCOLOR=#cc6600 ALIGN="center" ><FONT FACE="Verdana, Arial, Helvetica, sans-serif">1</FONT></TD>
<TD BGCOLOR=#CC6600 ALIGN="left" ><FONT FACE="Verdana, Arial, Helvetica, sans-serif">Wachtell, Lipton</FONT></TD>
<TD BGCOLOR=#CC6600 ALIGN="center" ><FONT FACE="Verdana, Arial, Helvetica, sans-serif">1 </FONT></TD>
<TD BGCOLOR=#CC6600 ALIGN="center" ><FONT FACE="Verdana, Arial, Helvetica, sans-serif">9.1%</FONT></TD>
<TD BGCOLOR=#FF9933 ALIGN="center" ><FONT FACE="Verdana, Arial, Helvetica, sans-serif">$3,385,000 </FONT></TD>
</TR>
我正在尝试获取第一个 ALIGN="left" 和最后一个 ALIGN="center"。但是最后一行的索引给出了错误。这是我正在使用的代码:
soup = BeautifulSoup(urllib.urlopen("http://www.law.com/special/professionals/amlaw/amlaw200/amlaw200_ppp.html"))
rows = soup.findAll(name='tr',attrs={'valign':'bottom'}, limit=13)
for row in rows:
tds_left = row.findAll(name='td',attrs={'align':'left'}, limit=13)
tds_center = row.findAll(name='td',attrs={'align':'center'}, limit=13)
if tds_left:
firm_name = tds_left[0].text
if tds_center:
# the following line gives an error if the index is different than 0
ppp = tds_center[0].text
谢谢!
更新
Traceback (most recent call last):
File "C:\Program Files (x86)\Google\google_appengine\google\appengine\ext\webapp\_webapp25.py", line 701, in __call__
handler.get(*groups)
File "C:\U\A\D\\toplawfirms.py", line 384, in get
ppp = tds_center[2].text
IndexError: list index out of range
更新
作为对agf 评论的回复,这里有print tds_center 和for item in tds_center: print item?
tds_center: []
tds_center: []
tds_center: []
tds_center: [ ]
item:
tds_center: []
item:
tds_center: [Rank By
Profits Per
Partner, Rank By
Revenue
Per Lawyer, Change In
Profits per
Partner
from 1998, Profits Per
Partner]
item: Rank By
Profits Per
Partner
item: Rank By
Revenue
Per Lawyer
item: Change In
Profits per
Partner
from 1998
item: Profits Per
Partner
tds_center: [1, 1 , 9.1%, $3,385,000 ]
item: 1
item: 1
item: 9.1%
item: $3,385,000
tds_center: [2, 2 , 5.0%, $3,055,000 ]
item: 2
item: 2
item: 5.0%
item: $3,055,000
tds_center: [3, 4 , 2.9%, $2,110,000 ]
item: 3
item: 4
item: 2.9%
item: $2,110,000
tds_center: [4, 3 , 8.7%, $1,790,000 ]
item: 4
item: 3
item: 8.7%
item: $1,790,000
tds_center: [5, 9 , 6.9%, $1,710,000 ]
item: 5
item: 9
item: 6.9%
item: $1,710,000
tds_center: [6, 6 , 10.8%, $1,655,000 ]
item: 6
item: 6
item: 10.8%
item: $1,655,000
tds_center: [7, 5 , 5.1%, $1,610,000 ]
item: 7
item: 5
item: 5.1%
item: $1,610,000
【问题讨论】:
-
请显示完整的回溯,以便我们知道错误的来源。
-
print tds_center显示什么?for item in tds_center: print item呢? -
@Thomas K:我添加了完整的回溯。谢谢。
-
@agf:我在问题中添加了值。谢谢
标签: python screen-scraping beautifulsoup web-scraping