How to find an element which contains   using

2020-04-17 06:19发布

<td>By Company&nbsp;&nbsp;</td>

I need to capture xpath of the above element. I tried following alternatives, but nothing seems to be working in chrome. Can you please suggest any other option.

"//td[normalize-space(text())='By Company\u00a0']"
"//td[normalize-space(text())='By Company\u00a0\u00a0']"
"//td[text()='By Company\u00a0']"
"//td[text()[normalize-space(.)='By Company\u00a0']]"
"//td[text()[normalize-space()='By Company\u00a0']]"

2条回答
你好瞎i
2楼-- · 2020-04-17 06:58

Ignore it, locate by "By Company" only

//td[contains(., 'By Company')]
查看更多
Root(大扎)
3楼-- · 2020-04-17 07:06

To locate the element:

<td>By Company&nbsp;&nbsp;</td>

You can use either of the following :

  • Using text():

    "//td[text()='By Company\u00A0\u00A0']"
    
  • Using contains():

    "//td[contains(., 'By Company\u00A0\u00A0')]"
    

However, ideally you may like to avoid the NO-BREAK SPACE character and use either of the following solutions:

  • Using starts-with():

    "//td[starts-with(., 'By Company')]"
    
  • Using contains():

    "//td[contains(., 'By Company')]"
    

Reference

You can find a relevant detailed discussion in:


tl; dr

Unicode Character 'NO-BREAK SPACE' (U+00A0)

查看更多
登录 后发表回答