我正在尝试修改Selenium的Xero批量发票删除工具。开箱即用,它只是按照列排序的顺序删除发票。
但我想要做的是删除所有带有特定前缀的参考和包含2014的日期的发票。
我已成功修改了提供的示例中的定位,以使用css选择器选择正确的前缀(包含" css = td.ref:包含的行(" WEB") ")如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head profile="http://selenium-ide.openqa.org/profiles/test-case">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="selenium.base" href="https://go.xero.com/" />
<title>DeleteAllAccountsReceivables</title>
</head>
<body>
<table cellpadding="1" cellspacing="1" border="1">
<thead>
<tr><td rowspan="1" colspan="3">DeleteAllAccountsReceivables</td></tr>
</thead><tbody>
<tr>
<td>getEval</td>
<td>X=0</td>
<td></td>
</tr>
<tr>
<td>getEval</td>
<td>Items=5000</td>
<td></td>
</tr>
<tr>
<td>while</td>
<td>X<Items</td>
<td></td>
</tr>
<tr>
<td>openAndWait</td>
<td>/AccountsReceivable/Search.aspx?invoiceStatus=INVOICESTATUS/AUTHORISED</td>
<td></td>
</tr>
<tr>
<td>clickAndWait</td>
<td>css=td.ref:contains("WEB")</td>
<td></td>
</tr>
<tr>
<td>click</td>
<td>link=Void</td>
<td></td>
</tr>
<tr>
<td>pause</td>
<td>1000</td>
<td></td>
</tr>
<tr>
<td>clickAndWait</td>
<td>css=button:contains('OK')</td>
<td></td>
</tr>
<tr>
<td>getEval</td>
<td>X++</td>
<td></td>
</tr>
<tr>
<td>endWhile</td>
<td></td>
<td></td>
</tr>
</tbody></table>
</body>
</html>
我真正需要它做的是测试上述和这个条件:
css=td.from + td:contains("2014")
如果两者都匹配,则继续。到目前为止,将它放在另一行ClickAndWait中并不起作用,因为它已经加载到下一页。
这是我第一次使用Selenium,而我似乎找不到任何创建复合目标的方法。我也试过使用&#39; while&#39;但没有成功。
答案 0 :(得分:1)
我没有使用Selenium的Xero批量发票删除工具。但我假设它是一个用Selenium IDE编写的脚本
我认为我们可以使用xpath使用以下符号。
xpath=//td[contains(text(),'from')][contains(text(),'2014')]
或
xpath=//td[contains(text(),'from') and contains(text(),'2014')]
编辑 - 基于HTML源代码发布
您可以使用以下xpath。这个会找到包含tr
的{{1}},文字包含'LDE',另一个td
的文字包含'2014'
td
如果要查看所需行的复选框,请使用以下xpath:
xpath=//tr[//td[@class='ref'][contains(text(),'LDE')]][//td[@class='from']/following-sibling::td[1][contains(text(),'2014')]]
希望这会对你有所帮助。