我尝试使用 Excel 工作表自动填充 CMS。 在我的 CMS 中,我想将标签链接到我的 ID 对象。 标签是一个可供选择的列表。 所以我的 Excel 表格基本上是 2 列(ID 和标签)
到目前为止,除了一个按钮之外,一切都运行良好。该按钮将标签链接到其对象,它不是提交按钮,而是无类型按钮。
<button class="btn btn-info link_tag">Link</button>
这是部分代码:
# fill in the 'tag' form
driver.find_element_by_name('Tag').send_keys('tag_name')
# link the tag with the ID
driver.find_element_by_xpath('//*[@id="form1"]/fieldset[2]/div/div[2]/div/div/div/div[2]//*[@class="btn btn-info link_tag"]').click()
首先我填写此字段,然后会出现建议的下拉列表
Google 示例:
但是,在此之后,我应该链接标签的按钮“链接”不起作用。我没有任何错误消息,它只是不执行任何操作。该按钮不是提交类型,所以我认为问题来自于此?或者问题可能来自于标签表单是一个搜索表单(它会显示建议)?
还要注意 selenium 打开的网络浏览器,我自己也无法用鼠标单击该按钮。我点击它但没有任何反应。我必须重写标签才能将我的标签链接到我的 ID。但是,如果我从下拉列表中选择该选项,那么我可以单击该按钮。
下面有一个提交按钮(“保存”),可以使用,但由于标签未与 ID 链接,因此没有任何可保存的内容。
如果是人为完成的,则可以通过按 ENTER 或单击此“链接”按钮或 Tab 键来链接标签
我尝试使用send_keys(u'\ue007')、send_keys(Keys.ENTER)、send_keys(Keys.TAB)、click()、time.wait来等待页面退出,但这些解决方案都不起作用(在填充字段和链接按钮)。
有什么办法可以解决这个问题吗?
最佳答案
更新,我找到了解决方案,这实际上很愚蠢..
# fill in the 'tag' form
tag = driver.find_element_by_name('Tag')
tag.send_keys('tag_name')
tag.send_keys(u'\ue007')
# link the tag with the ID
driver.find_element_by_xpath('//*[@id="form1"]/fieldset[2]/div/div[2]/div/div/div/div[2]//*[@class="btn btn-info link_tag"]').send_keys("\n")
这对我有用。我需要找到一种方法来“验证”下拉列表中的选项,因此按 Enter 键可以解决我的问题。
此外,“提交/保存”按钮无法正常工作,因此我尝试等待几秒钟(它有效),但这不是理想的解决方案。但是添加 send_key("\n") 对我有用。
关于Python Selenium - 自动填写表单 - 单击不是提交按钮的按钮并从列表中填写表单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59932546/