简体   繁体   English

无法使用 Python Selenium 选择项目我做错了什么?

[英]Unable to select item using Python Selenium What am I doing wrong?

this is my first post on stack overflow and I did some searching but couldn't find the solution to my problem.这是我关于堆栈溢出的第一篇文章,我做了一些搜索,但找不到解决我的问题的方法。 Apologies if the answer to this question is obvious/posted elsewhere.如果这个问题的答案很明显/张贴在其他地方,我们深表歉意。

So, I'm an English teacher and I'm trying to make a small script that will copy feedback from my companies website and parse it into an excel spreadsheet.所以,我是一名英语老师,我正在尝试制作一个小脚本,该脚本将复制我公司网站的反馈并将其解析为 Excel 电子表格。 I've done the 'Automate the boring stuff with Python' course so I've had a little practice with Selenium, but I cannot get Selenium to select the username/password text boxes on my companies login page.我已经完成了“用 Python 自动化无聊的东西”课程,所以我对 Selenium 进行了一些练习,但是我无法让 Selenium 在我的公司登录页面上选择用户名/密码文本框。 I've tried tags, classes, CSS selectors, and XPath selectors.我尝试过标签、类、CSS 选择器和 XPath 选择器。 Nothing will work.什么都行不通。

To make sure I did a simple Google search using a CSS selector using the same setup and that worked fine.为了确保我使用 CSS 选择器使用相同的设置进行了简单的 Google 搜索,并且效果很好。 So perhaps it's the way the HTML is written?所以也许这就是 HTML 的编写方式?

Screenshot of HTML HTML 的屏幕截图

HTML: HTML:

<div data-v-e72e25c2="" class="username ipt-box"><img data-v-e72e25c2="" src="" alt="" class="head-icon"> <input data-v-e72e25c2="" type="text" placeholder="Email Address"> <span data-v-e72e25c2=""></span></div>

My code:我的代码:

from openpyxl import Workbook
wb = Workbook()
from openpyxl import load_workbook
from openpyxl.utils import get_column_letter

import datetime
import os
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common import keys
import requests
import time

#Fixed Variables
fileDirectory = "c:\\User\\Documents\\Coding\\feedbackReport"
os.chdir("c:\\Users\\Documents\\Coding\\feedbackReport")
scanWorkbook = os.listdir(fileDirectory)
dest_filename = 'Progess_Reports.xlsx'
workBookLoaded = 0
username = 'test@gmail.com'

#Detect if excel sheet exists, if no, create one, if yes, open it

if scanWorkbook.count(dest_filename) == 1:
    wb = load_workbook(filename = dest_filename)
    ws0 = wb.active
    workBookLoaded = 1
    print("Workbook loaded")

if workBookLoaded == 0:
    print("New WB Created")
    ws0 = wb.active
    ws0.title  = 'Reports'
    ws0['A2'] = "Session Time"
    ws0["B2"] = "Session Type"
    ws0["C2"] = "Student"
    ws0["D2"] = "Rating"
    ws0["E2"] = "Compliments"
    ws0["F2"] = "Suggestions"
    wb.save(filename = dest_filename)


#Access feedback section


browser = webdriver.Firefox()


#Manage the login page
browser.get('https://test.com')
time.sleep(8)
#usernameField = browser.find_element_by_css_selector("css=.username > input")
#usernameField = browser.find_elements_by_class_name('username')
#usernameField = browser.find_element_by_tag_name(r'input data-v-e72e25c2="" type="text" placeholder="Email Address"')
#usernameField = browser.find_element_by_xpath("xpath=//input[@type='text']")

usernameField.send_keys(username)




Can anyone confirm what I'm doing wrong?谁能确认我做错了什么? I've included a small number of my selection attempts for reference.我已经包含了一小部分我的选择尝试以供参考。 Also, any comments/suggestions regarding any aspect of my code are warmly welcomed.此外,热烈欢迎有关我的代码的任何方面的任何评论/建议。

Please let me know if any further information is required.如果需要任何进一步的信息,请告诉我。

看看这是否有效

driver.find_element_by_xpath("//input[@placeholder='Email Address']").send_keys(username)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM