我需要检查具有复合类的span中是否存在特定文本,但selenium根本没有在页面上找到此元素。
我已经尝试过使用class和xpath,但是找不到它。
我需要获取文字的完整HTML代码:
<span class="mn-person-info__occupation mn-person-info__occupation--card-layout Sans-13px-black-55%">
Consultor de RH - HProjekt
</span>
完整的HTML代码:
<div class="mn-person-info__card-details mt1">
<a data-control-name="pymk_profile" href="/in/kaique-soares-04798354/" id="ember1053" class="mn-person-info__link ember-view"> <span class="visually-hidden">Nome do usuário</span>
<span class="mn-person-info__name
mn-person-info__name--card-layout Sans-15px-black-85%-semibold">
Kaique Soares
</span>
<span class="visually-hidden">Cargo do usuário</span>
<span class="mn-person-info__occupation
mn-person-info__occupation--card-layout Sans-13px-black-55%">
Consultor de RH - HProjekt
</span>
</a>
<div class="mn-person-info__shared-insights display-flex justify-center pt1 ph2">
<button data-control-name="see_all_common_connections" class="mn-person-info__shared-insights-btn Sans-13px-black-55%" data-ember-action="" data-ember-action-1256="1256">
<span class="mn-person-info__shared-insights-icon svg-icon-wrap"><li-icon aria-hidden="true" type="in-common-icon" size="small"><svg viewBox="0 0 24 24" width="24px" height="24px" x="0" y="0" preserveAspectRatio="xMinYMin meet" class="artdeco-icon"><g class="small-icon" style="fill-opacity: 1">
<path d="M11,3C9.9,3,8.9,3.4,8,4C5.8,2.3,2.7,2.8,1,5s-1.2,5.3,1,7c0.9,0.6,1.9,1,3,1s2.1-0.4,3-1c2.2,1.7,5.3,1.2,7-1s1.2-5.3-1-7C13.1,3.4,12.1,3,11,3z M1.9,8c0-1.7,1.4-3.1,3.1-3.1c0.6,0,1.2,0.2,1.7,0.5c-1,1.6-1,3.6,0,5.2c-1.4,1-3.4,0.6-4.3-0.8C2.1,9.2,1.9,8.6,1.9,8z M11,11.1c-0.6,0-1.2-0.2-1.7-0.5c1-1.6,1-3.6,0-5.2c1.4-1,3.4-0.6,4.3,0.9s0.6,3.4-0.9,4.3C12.2,10.9,11.6,11.1,11,11.1z"/>
</g></svg></li-icon></span>
<span class="mn-person-info__shared-insights-count">
Fernando Abrantes e mais 76 pessoas
</span>
</button>
</div>
</div>
我尝试了这些方法甚至等待但仍未找到元素:
String text = driver.findElement(By.className("mn-person-info__occupation.mn-person-info__occupation--card-layout.Sans-13px-black-55%")).getText();
System.out.println(text);
driver.findElement(By.className("mn-person-info__occupation.mn-person-info__occupation--card-layout.Sans-13px-black-55%")).getText();
WebElement text = driver.findElement(By.className("mn-person-info__occupation.mn-person-info__occupation--card-layout.Sans-13px-black-55%")).getText();
System.out.println("text");
答案 0 :(得分:2)
方法By.className
采用以空格分隔的类,但您使用的是点。
在你的情况下,一堂课应该足够了:
By.className("mn-person-info__occupation--card-layout")
,或使用CSS选择器:
By.cssSelector(".mn-person-info__occupation--card-layout")
请注意,某些类具有非法字符,例如%
。对于那些你必须使用带有属性过滤器的CSS选择器:
By.cssSelector(".mn-person-info__occupation--card-layout[class*='Sans-13px-black-55%']")
答案 1 :(得分:1)
请试试这个xpath。
String content = driver.findElement(by.xpath("//div[class='mn-person-info__card-details mt1']/a[1]/spam[3]")).getText();
希望这会有所帮助。感谢。
答案 2 :(得分:1)
试试这个:
WebElement myelement = driver.findElement(By.xpath("//div[@class='mn-person-info__card-details mt1']a[1]/span[3]"));
//Now get the text.
String mytext = descriptionEle.getText();
答案 3 :(得分:1)
如果您尝试使用此
String content = driver.findElement(by.xpath("//span[class='mn-person-info__occupation']")).getText();
答案 4 :(得分:0)
问题是由By选择器引起的。它看起来很奇怪,而selenium无法处理它。 Selenium不喜欢选择器中有%。
如果你想通过classname使用,那么我建议你去一个更容易的路线。
String text = driver.findElement(By.className("mn-person-info__occupation")).getText();
System.out.println(text);
或者使用其他选项。
String text2 = driver.findElement(By.className("mn-person-info__occupation--card-layout")).getText();
System.out.println(text2);