我从excel文件发送定义的数据。我尝试了一些代码,但他们没有在某个时间点从excel文件中选择所有数据代码给了我未找到WebElement的异常。
以下是HTML代码:
<div class="ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix">
<div id="addDialog" class="hidden ui-dialog-content ui-widget-content" style="display: block; width: auto; min-height: 30px; height: auto; max-height: 351.05px; overflow-y: auto;">
<div class="field-container">
<fieldset class="field-container">
<legend>Contracts:</legend>
<a class="select-all" href="#">Select All</a>
<a class="deselect-all" href="#">Deselect All</a>
<select id="addContract" class="searchable" multiple="multiple" style="position: absolute; left: -9999px;">
<option value="93370956">93370956</option>
<option value="93796167">93796167</option>
<option value="94203239">94203239</option>
</select>
<div id="ms-addContract" class="ms-container">
<div class="ms-selectable">
<input class="search-input" type="text" placeholder="filter" autocomplete="off"/>
<ul class="ms-list" tabindex="-1">
<li id="86355560-selectable" class="ms-elem-selectable">
<span>93370956</span>
</li>
<li id="202890296-selectable" class="ms-elem-selectable">
<span>93796167</span>
</li>
<li id="938848030-selectable" class="ms-elem-selectable">
<span>94203239</span>
</li>
</ul>
</div>
</div>
需要从列表中选择值。 所做的努力: 代码的这种努力起作用,但它只选择了一个值,然后给出了异常
WebDriverWait Wait=new WebDriverWait(driver, 10);
Wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//ul[@class='ms-list']/li/span")));
//now you can find element
List<WebElement>options=driver.findElements(By.xpath("//ul[@class='ms-list']/li/span[contains(text(),'"+testData+"')]"));
for (WebElement option: options) {
if(testData.equals(option.getText())) option.click();
}
尝试上面的代码,但它只选择一个值!!
WebDriverWait Wait = new WebDriverWait(driver, 10);
Wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//*[@id='ms-addContract']//descendant::div[@class='ms-selectable']/ul[@class='ms-list']]//span")));
List<WebElement> options = driver.findElements(By.xpath("//*[@id='ms-addContract']//descendant::div[@class='ms-selectable']/ul[@class='ms-list']]//span[contains(text(), '"+testData+"')]"));
for (WebElement option : options) {
if(testData.equals(option.getText()))
option.click();--tried this xpath-no success
WebDriverWait wait = new WebDriverWait(driver, 10);
wait.until(ExpectedConditions.visibilityOfElementLocated(By.xpath(".//*[@id='ms-addContract']/div[1]/input"))).click();
driver.findElement(By.xpath(".//*[@id='ms-addContract']/div[1]/input")).sendKeys(testData);
WebDriverWait wait1 = new WebDriverWait(driver, 10);
wait1.until(ExpectedConditions.visibilityOfElementLocated(By.xpath(".//*[@id='ms-addContract']/div[1]/input"))).sendKeys(Keys.ARROW_DOWN,Keys.ARROW_DOWN,Keys.SPACE);
//Clear the input text value.
driver.findElement(By.xpath(".//*[@id='ms-addContract']/div[1]/input")).clear();---worked but not satisfactory
请找到该元素的帮助。我使用excel文件中的关键字驱动框架读取值。
答案 0 :(得分:0)
听起来你正试图获得ul元素中包含的所有span元素(尽管如果我错了,请纠正我)。这是您正在使用的代码:
List<WebElement>options = driver.findElements(By.xpath("//ul[@class='ms-list']/li/span[contains(text(),'"+testData+"')]"));
在您的情况下,此XPath将只返回1个值。这是因为您尝试使用输入值“testData”匹配每个span的内容。如果你想获得ul里面的所有span元素,那么使用:
List<WebElement>options = driver.findElements(By.xpath("//ul[@class='ms-list']/li/span"));
此XPath将选择完成选择列表中的所有span元素。如果您只需要选择testData中包含文本的span元素,那么您可以选择适当的元素来迭代该列表:
ArrayList<WebElement> optionsInTestData = new ArrayList<WebElement>();
for(WebElement element: options){
for(String data: testData){
if(element.getText() == data){
optionsInTestData.add(element);
}
}
}