Форум программистов, компьютерный форум, киберфорум
Python: Web
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/18: Рейтинг темы: голосов - 18, средняя оценка - 5.00
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393

Парсинг форм ввода

31.07.2021, 10:03. Показов 3313. Ответов 8

Студворк — интернет-сервис помощи студентам
Здравствуйте, всем.

Пишу скрипт, который должен автоматически заполнять налоговую декларацию по доходам за пределами РФ.
Большая часть скрипт уже написана.
Когда нажимается “добавить источник” не получается найти элемент который раскрывает список, как найти формы в каждом новым источнике, чтобы заполнить их?

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import json
from bs4 import BeautifulSoup
import requests as req
 
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.chrome.options import Options
import os, time, keyboard
def check(driver):
  url = driver.current_url
  time.sleep(2)
  try:
    response = req.get(url=url)
    print(f" {url} {response.status_code}")
    return 0
  except Exception as ex:
     check(driver)
 
path_to_extension=r"C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx"
options = Options()
options.add_experimental_option("excludeSwitches", ['enable-automation']) # убрать окно
# options.add_argument('--profile-directory=Profile 2')
# options.add_argument(r'--C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx')
 
options.add_extension(r'C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx')
options.add_argument("--incognito")
prefs = {'safebrowsing.enabled': True,
         "credentials_enable_service": False,
         "profile.password_manager_enabled" : False,
         # "select_file_dialogs.allowed": False,
         # "download.prompt_for_download": False,
         # "download.directory_upgrade": True,
         # "profile.default_content_setting_values.automatic_downloads": 1,
         # "download_restrictions": 0,
         # "profile.default_content_settings.popups": 0,
         "credentials_enable_service": False,
         "profile.password_manager_enabled": False
         }
options.add_experimental_option("prefs", prefs)
# options.add_argument('--disable-extensions')
options.add_argument('--disable-infobars')
options.add_argument('--safebrowsing-disable-extension-blacklist')
options.add_argument('--safebrowsing-disable-download-protection')
with open("password.json", "r") as json_file:
  a = json.load(json_file)
  user = a["gos"]["user_name"]
  password_for_gos =a["gos"]["password"]
 
try:
  
  driver = webdriver.Chrome(r'C:\Users\egor\chromedriver\92.0.4515.43\win32\chromedriver.exe', options=options)
  driver.get("https://lkfl2.nalog.ru/lkfl/login")
  while 1:
    time.sleep(1)
    try:
      if driver.find_element_by_class_name("form_link"):
         p= driver.find_elements_by_class_name("form_link")
         p[1].click()#вход на госуслуги.
         break
    except:
      if driver.find_element_by_class_name("popup_close"):
        driver.find_element_by_class_name("popup_close").click()
      pass
  
  print("close")
  time.sleep(1)
  login_input = driver.find_element_by_id("login")
  login_input.clear()
  login_input.send_keys(user)
  password = driver.find_element_by_id("password")
  password.clear()
  password.send_keys(password_for_gos)
  driver.find_element_by_class_name("ufoPC-checkbox").click()# не запоминать пароль.
  check(driver)
  driver.find_element_by_class_name("ui-button").click()# вход в налоговой кабинет.
  check(driver)
  driver.find_element_by_class_name("menu__main").find_element_by_class_name("menu_link__report").click()
  check(driver)# жизненные ситуации
  driver.find_element_by_xpath("/html/body/div[1]/div/div[1]/div[3]/div/div[3]/div[1]/div/div/div[3]/div/div[2]/a").click()
  # 3 ндфл
  check(driver)
  driver.find_element_by_class_name("Button_button__blue__Ipe-v").click()# далее
  check(driver)
  driver.find_element_by_id("react-tabs-2").click()# за пределами РФ
  
  check(driver)
  p= driver.find_element_by_class_name("form_buttons")#добавить источник
  p.find_element_by_class_name("src-modules-Taps-components-NDFL3-private-forms-IncomesForm-IncomesOutsideRFComponent-IncomeSources-IncomeSources-module__addButton").click()
  check(driver)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.07.2021, 10:03
Ответы с готовыми решениями:

Парсинг и заполнение форм WebBrowser WPF
Вот такого рода исключение ловлю... System.NullReferenceException: "Ссылка на объект не указывает на экземпляр объекта." Помогите...

Объединение форм ввода
Всем добрый день. Не получается отработать следующий момент в аксес. А именно: На примере вложенной БД. Есть родитель, у...

Создание больших форм ввода
Здравствуйте, нужен совет. Делаю приложение, основная задача которого - отправка заказов с большим числом полей ввода (40, 50 и более). ...

8
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
31.07.2021, 10:11  [ТС]
вот скриншот
Миниатюры
Парсинг форм ввода  
0
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
04.08.2021, 10:42  [ТС]
вот пока прогресс
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import json
from bs4 import BeautifulSoup
import requests as req
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.support.ui import Select
import os, time, keyboard
from selenium.webdriver.common.by import By
def get(driver):
  url = driver.current_url
  resp = req.get(url)
  soup = BeautifulSoup(resp.text, 'lxml')
  html = soup.prettify("utf-8")
  with open("output.html", "wb") as file:
    file.write(html)
 
  #print(soup.findAll)
  # res =soup.findAll("div",
  #                id="Ndfl3Package.payload.sheetB.sources[0].incomeSourceName")
  # for i in res:
  #  print(res)
  #
def check(driver):
  url = driver.current_url
  time.sleep(3)
  try:
    response = req.get(url=url)
    # print(f" {url} {response.status_code}")
    return 0
  except Exception as ex:
     check(driver)
 
path_to_extension=r"C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx"
options = Options()
options.add_experimental_option("excludeSwitches", ['enable-automation']) # убрать окно
# options.add_argument('--profile-directory=Profile 2')
# options.add_argument(r'--C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx')
 
options.add_extension(r'C:\Users\egor\chromedriver\92.0.4515.43\win32\public_services_1.2.8.0.crx')
options.add_argument("--incognito")
prefs = {'safebrowsing.enabled': True,
         "credentials_enable_service": False,
         "profile.password_manager_enabled" : False,
         # "select_file_dialogs.allowed": False,
         # "download.prompt_for_download": False,
         # "download.directory_upgrade": True,
         # "profile.default_content_setting_values.automatic_downloads": 1,
         # "download_restrictions": 0,
         # "profile.default_content_settings.popups": 0,
         "credentials_enable_service": False,
         "profile.password_manager_enabled": False
         }
options.add_experimental_option("prefs", prefs)
# options.add_argument('--disable-extensions')
options.add_argument("--disable-blink-features=AutomationControlled")
options.add_argument('--disable-infobars')
options.add_argument('--safebrowsing-disable-extension-blacklist')
options.add_argument('--safebrowsing-disable-download-protection')
with open("password.json", "r") as json_file:
  a = json.load(json_file)
  user = a["gos"]["user_name"]
  password_for_gos =a["gos"]["password"]
 
try:
  
  driver = webdriver.Chrome(r'C:\Users\egor\chromedriver\92.0.4515.43\win32\chromedriver.exe', options=options)
  driver.get("https://lkfl2.nalog.ru/lkfl/login")
  while 1:
    time.sleep(1)
    try:
      if driver.find_element_by_class_name("form_link"):
         p= driver.find_elements_by_class_name("form_link")
         p[1].click()#вход на госуслуги.
         break
    except:
      if driver.find_element_by_class_name("popup_close"):
        driver.find_element_by_class_name("popup_close").click()
      pass
  print("close")
  time.sleep(1)
  login_input = driver.find_element_by_id("login")
  login_input.clear()
  login_input.send_keys(user)
  password = driver.find_element_by_id("password")
  password.clear()
  password.send_keys(password_for_gos)
  driver.find_element_by_class_name("ufoPC-checkbox").click()# не запоминать пароль.
  check(driver)
  driver.find_element_by_class_name("ui-button").click()# вход в налоговой кабинет.
  check(driver)
  driver.find_element_by_class_name("menu__main").find_element_by_class_name("menu_link__report").click()
  check(driver)# жизненные ситуации
  driver.find_element_by_xpath("/html/body/div[1]/div/div[1]/div[3]/div/div[3]/div[1]/div/div/div[3]/div/div[2]/a").click()
  # 3 ндфл
  check(driver)
  driver.find_element_by_class_name("Button_button__blue__Ipe-v").click()# далее
  check(driver)
  driver.find_element_by_id("react-tabs-2").click()# за пределами РФ
  
  check(driver)
  p= driver.find_element_by_class_name("form_buttons")#добавить источник
  p.find_element_by_class_name("src-modules-Taps-components-NDFL3-private-forms-IncomesForm-IncomesOutsideRFComponent-IncomeSources-IncomeSources-module__addButton").click()
  check(driver)
  driver.find_element_by_class_name("src-modules-Taps-components-NDFL3-private-forms-IncomesForm-IncomesOutsideRFComponent-IncomeSources-IncomeSources-module__spoilerTitle").click()
  comp= "X5 RETAIL GROUP"
  name_id ="Ndfl3Package.payload.sheetB.sources[0].incomeSourceName"
  res= driver.find_element_by_id(name_id)
  res.clear()
  res.send_keys(comp)
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,663
Записей в блоге: 29
04.08.2021, 11:36
не хочу расстраивать, но это не прогресс пока, Суп не используют вместе с селениум (потомучто последний парсит лучше), ну и локаторы ты пока не умеешь создавать, в одной из тем кинул тебе ссылку
0
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
04.08.2021, 19:30  [ТС]
Welemir1, спасибо большое за ваше внимание. я пока новичок, что такое локатор?. по-моему с помощью Soup легче находить нужные элементы, чем на selenium. хотя прекрасно понимаю, что они не совместимы.
Насчёт selenium с ним возникают при поиске элементов.
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,663
Записей в блоге: 29
04.08.2021, 19:37
Цитата Сообщение от Егор Щербанов Посмотреть сообщение
что такое локатор?
это способ найти элемент в верстке, например у вас это
Цитата Сообщение от Егор Щербанов Посмотреть сообщение
by_class_name("popup_close")
xpath локаторы у вас ужасны

Цитата Сообщение от Егор Щербанов Посмотреть сообщение
по-моему с помощью Soup легче находить нужные элементы, чем на selenium
нет
Цитата Сообщение от Егор Щербанов Посмотреть сообщение
Насчёт selenium с ним возникают при поиске элементов.
потому что вы не умеете искать, ознакомьтесь с той ссылкой что давал вам по xpath локаторам
0
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
05.08.2021, 22:07  [ТС]
Welemir1, спасибо большое за полезную ссылку. буду изучать, но на это требуется время.
мой скрипт заполняет налоговую декларацию, вроде всё работает, ну как-то криво, через костыли.
основная тема связана с так называемым выпадающим списком. необходимо выбрать нужный элемент из него.
Решил эту проблему, следующим образом с помощью эмулятора нажатия клавиш на клавиатуры.
так идёт заполнения нужных форм, но хотелось бы услышит от в этом людей ценные советы.
очень буду рад если кому-нибудь этот скрипт будет полезен.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
 comp= "X5 RETAIL GROUP"
  name_id ="Ndfl3Package.payload.sheetB.sources[0].incomeSourceName"
  res= driver.find_element_by_id(name_id)
  res.clear()
  res.send_keys(comp)# имя компании
  
  driver.find_element_by_xpath('//*[@id="react-select-8--value"]/div[1]').click()
  country ="528 - НИДЕРЛАНДЫ"
  div="1010 - Дивиденды"
  time.sleep(3)
  keyboa.write(country,delay=0.1)
  keyboa.send('enter')  # aliases: press_and_release
  
  time.sleep(3)
  driver.execute_script("window.scrollTo(0, 520)")
  driver.find_element_by_xpath('//*[@id="react-select-10--value"]/div[1]').click()
  keyboa.write(div,delay=0.1) # тип выплаты.
  keyboa.send('enter')
  
  time.sleep(3)
  driver.execute_script("window.scrollTo(0, 320)")
  driver.find_element_by_xpath('//*[@id="react-select-12--value"]/div[1]').click()
  keyboa.write("Не предоставлять вычет",delay=0.1)
  keyboa.send('enter')
  
  res= driver.find_element_by_name("Ndfl3Package.payload.sheetB.sources[0].incomeAmountCurrency")
  res.send_keys("2.56")# сколько получили
 
  driver.find_element_by_xpath('//*[@id="react-select-11--value"]/div[1]').click()
  keyboa.write("840 - Доллар США",delay=0.1)#
  keyboa.send('enter')
  
  p=driver.find_element_by_xpath('//*[@id="Ndfl3Package.payload.sheetB.sources[0].taxPaymentDate"]/div[2]/div[1]/div/div/input')
  p.click()
  p.send_keys("28.05.2021")# дата получения
 
  p=driver.find_element_by_xpath('//*[@id="Ndfl3Package.payload.sheetB.sources[0].incomeDate"]/div[2]/div[1]/div/div/input')
  p.click()
  p.send_keys("28.05.2021")# дата уплаты налога
  time.sleep(6)
  
  driver.find_element_by_xpath('//*[@id="Ndfl3Package.payload.sheetB.sources[0].paymentAmountCurrency"]').click()
  keyboa.write("0.46",delay=0.1) # сколько уплатили.
  keyboa.send('enter')
 
  driver.find_element_by_xpath('//*[@id="checkbox_3"]').click()
0
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
08.08.2021, 17:55  [ТС]
Благодаря вашим советам, cмог найти правильные xpath пути, теперь поля формы заполняются верно.
Но появилась новая проблема. Сбрасывается дата в календаре. Поэтому приходится повторять часть кода.
Может у кого-нибудь будут какие-нибудь мысли на этот счёт?

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
  comp= "X5 RETAIL GROUP"
  country ="528 - НИДЕРЛАНДЫ"
  received = "2.56" #Доход
  tax_on_dividends= "0.46" #Налог
  date='28.05.2021'
  
  name_id ="Ndfl3Package.payload.sheetB.sources[{}].oksm".format(0)
  name_id2 ="Ndfl3Package.payload.sheetB.sources[{}]".format(0)
  name_id3 = 'Ndfl3Package.payload.sheetB.sources[{}].incomeTypeCode'.format(0)
  name_id4 ='Ndfl3Package.payload.sheetA.sources[{}].taxRate'.format(2)
  name_id5 ='Ndfl3Package.payload.sheetB.sources[{}].incomeDate'.format(0)
  name_id6 ='Ndfl3Package.payload.sheetB.sources[{}].taxDeductionCode'.format(0)
  name_id7 = 'Ndfl3Package.payload.sheetB.sources[{}].taxPaymentDate'.format(0)
  name_id8 = 'Ndfl3Package.payload.sheetB.sources[{}].incomeAmountCurrency'.format(0)
  name_id9 = 'Ndfl3Package.payload.sheetB.sources[{}].paymentAmountCurrency'.format(0)
  name_id10 = 'Ndfl3Package.payload.sheetB.sources[{}].currencyCode'.format(0)
 
  adress='//*[@class="form_wrapper"]//*[@id="{}.incomeSourceName"]'.format(name_id2)
 
  driver.find_element_by_xpath(adress).send_keys(comp)# имя компании
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
  adress='//*[@id="{}"]//*[@id="react-select-8--value"]/div[1]'.format(name_id)
 
  driver.find_element_by_xpath(adress).click()
  class1='Select-multi-value-wrapper'
  select_contry='react-select-8--value'
  adress='//*[@id="{}"]//*[@class="{}" and @id="{}"]//*[@class="Select-input"]/input'.format(name_id, class1, select_contry)
  driver.find_element_by_xpath(adress).send_keys(country)
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  driver.execute_script("window.scrollTo(0, 520)")
  payment_type= 'react-select-10--value'
  adress='//*[@id="{}"]//*[@class="{}" and @id="{}"]//*[@class="Select-input"]/input'.format(name_id3, class1, payment_type)
 
  driver.find_element_by_xpath(adress).send_keys("1010 - Дивиденды")# тип выплаты.
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  driver.execute_script("window.scrollTo(0, 420)")
 
  class1='Select-control'
  class2='Select-arrow-zone'
  adress='//*[@id="{0}"]//*[@class="{1}"]/*[@class="{2}"]/*[@class="Select-arrow"]'.format(name_id6, class1, class2)
  driver.find_element_by_xpath(adress).click()
  
# //*[@id="Ndfl3Package.payload.sheetB.sources[0].taxDeductionCode"]//*
# [@class="Select-control"]//*[@class="Select-multi-value-wrapper" and
# @id="react-select-14--value"]//*[@role="combobox"]
  class2='Select-multi-value-wrapper'
  id_name='react-select-14--value'
  adress ='//*[@id="{0}"]//*[@class="{1}"]//*[@class="{2}" and @id="{3}"]//*[@role="combobox"]'.format(name_id6, class1,class2, id_name)
  driver.find_element_by_xpath(adress).send_keys("Не предоставлять вычет")
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  #//*[@class="form_wrapper"]//*[@name="Ndfl3Package.payload.sheetB.sources[0].incomeAmountCurrency"
  # and @id="Ndfl3Package.payload.sheetB.sources[0].incomeAmountCurrency"]
  adress='//*[@class="form_wrapper"]//*[@name="{0}" and @id="{0}"]'.format(name_id8)
 
  driver.find_element_by_xpath(adress).send_keys(received)# сколько получили
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  driver.execute_script("window.scrollTo(0, 460)")
  
  #//*[@id="Ndfl3Package.payload.sheetB.sources[0].incomeDate"]
  # //*[@class="react-datepicker-wrapper"]
  # //*[@class="react-datepicker__input-container"]//input
  class1='react-datepicker-wrapper'
  class2='react-datepicker__input-container'
  adress='//*["{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id5,class1,class2)
  
  # driver.find_element_by_xpath(adress).send_keys(date)#Дата получения дохода *
  # driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
 # //*[@id="Ndfl3Package.payload.sheetB.sources[0].taxPaymentDate"]//*[@class="react-datepicker-wrapper"]
  # //*[@class="react-datepicker__input-container"]//input
  class1='react-datepicker-wrapper'
  class2='react-datepicker__input-container'
  adress='//*[@id="{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id7,class1,class2)
  driver.find_element_by_xpath(adress).click()
  driver.find_element_by_xpath(adress).send_keys(date)# дата уплаты налога
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  #//*[@id="Ndfl3Package.payload.sheetB.sources[0].incomeDate"]
  # //*[@class="react-datepicker-wrapper"]
  # //*[@class="react-datepicker__input-container"]//input
  class1='react-datepicker-wrapper'
  class2='react-datepicker__input-container'
  adress='//*["{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id5,class1,class2)
  driver.find_element_by_xpath(adress).send_keys(date)#Дата получения дохода *
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
  
  #//*[@class="help-wrap"]//*[@id="Ndfl3Package.payload.sheetB.sources[0].currencyCode"]
  # //*[@class="Select-multi-value-wrapper" and @id="react-select-11--value"]//*[@class="Select-input"]//input
  id_name='react-select-11--value'
  class1='Select-multi-value-wrapper'
  class2='Select-input'
  adress='//*[@class="help-wrap"]//*[@id="{0}"]//*[@class="{1}" and @id="{2}"]//input'\
    .format(name_id10, class1, id_name, class2) # валюта
  driver.find_element_by_xpath(adress).send_keys("840 - Доллар США")
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  #///*[@class="form_wrapper"]//*[@name="Ndfl3Package.payload.sheetB.sources[0].paymentAmountCurrency"
  # and @id="Ndfl3Package.payload.sheetB.sources[0].paymentAmountCurrency"]
  adress='//*[@class="form_wrapper"]/*[@name="{0}" and @id="{0}"]'.format(name_id9)
  driver.find_element_by_xpath(adress).send_keys(tax_on_dividends)
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
  class1='react-datepicker-wrapper'
  class2='react-datepicker__input-container'
  adress='//*["{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id5,class1,class2)
  driver.find_element_by_xpath(adress).send_keys(date)#Дата получения дохода *
  driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
0
11 / 10 / 2
Регистрация: 19.02.2018
Сообщений: 393
10.08.2021, 12:20  [ТС]
Здравствуйте всем.
Наконец-то я закончил работу над скриптом.
Теперь налоговая декларация о доходах c иностранных компаний заполняется автоматически.
Возможно, ее будет полезна, небольшая доработка.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
import json
from bs4 import BeautifulSoup
import requests as req
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.support.ui import Select
import os, time
import keyboard as keyboa
from selenium.webdriver.common.by import By
 
 
def check(driver):
  url = driver.current_url
  driver.implicitly_wait(3)
  # time.sleep(3)
  try:
    response = req.get(url=url)
    # print(f" {url} {response.status_code}")
    return 0
  except Exception as ex:
     check(driver)
 
options = Options()
options.add_experimental_option("excludeSwitches", ['enable-automation']) # убрать окно
options.add_argument("--incognito")
 
prefs = {'safebrowsing.enabled': True,
         "credentials_enable_service": False,
         "profile.password_manager_enabled" : False,
         "credentials_enable_service": False,
         "profile.password_manager_enabled": False
         }
options.add_argument("user-agent=Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Safari/537.36")
options.add_experimental_option("prefs", prefs)
options.add_argument("--disable-blink-features=AutomationControlled")
options.add_argument('--disable-infobars')
options.add_argument('--safebrowsing-disable-extension-blacklist')
options.add_argument('--safebrowsing-disable-download-protection')
with open("password.json", "r") as json_file:
  a = json.load(json_file)
  user = a["gos"]["user_name"]
  password_for_gos =a["gos"]["password"]
 
try:
  
  driver = webdriver.Chrome(r'C:\Users\egor\chromedriver\92.0.4515.43\win32\chromedriver.exe', options=options)
  driver.get("https://lkfl2.nalog.ru/lkfl/login")
  while 1:
    time.sleep(1)
    try:
      if driver.find_element_by_class_name("form_link"):
         p= driver.find_elements_by_class_name("form_link")
         p[1].click()#вход на госуслуги.
         break
    except:
      if driver.find_element_by_class_name("popup_close"):
        driver.find_element_by_class_name("popup_close").click()
      pass
  print("close")
  check(driver)
  login_input = driver.find_element_by_id("login")
  login_input.clear()
  login_input.send_keys(user)
  password = driver.find_element_by_id("password")
  password.clear()
  password.send_keys(password_for_gos)
  driver.find_element_by_class_name("ufoPC-checkbox").click()# не запоминать пароль.
  driver.find_element_by_class_name("ui-button").click()# вход в налоговой кабинет.
  check(driver)
  driver.find_element_by_class_name("menu__main").find_element_by_class_name("menu_link__report").click()
  # жизненные ситуации
  
  driver.find_element_by_xpath('//*[@class="cRow"]/div[3]//*[@class="situations_info"]//a').click()
  check(driver)  # 3 ндфл
  driver.find_element_by_xpath('//*[@class="boo footer_controls white-block"]//*[@data-unit="next-button"]').click()
  # далее
  check(driver)
  driver.find_element_by_xpath('//*[@id="3NDFL"]//ul//*[@id="react-tabs-2"]').click()#за пределами РФ
 
  for i in range(1,2):
    adress='//*[@class="cRow"]//*[@class="form_buttons"]//*[@type="submit"]'
    driver.find_element_by_xpath(adress).click()#добавить источник
  
    number=1
    adress='//*[text()="Источник дохода №{0}"]'.format(number)
    ref= driver.find_element_by_xpath(adress).click()
  
    comp= "X5 RETAIL GROUP"
    country ="528 - НИДЕРЛАНДЫ"
    received = "2.56" #Доход
    tax_on_dividends= "0.46" #Налог
    date='28.05.2020'
  
    name_id ="Ndfl3Package.payload.sheetB.sources[{}].oksm".format(0)
    name_id2 ="Ndfl3Package.payload.sheetB.sources[{}]".format(0)
    name_id3 = 'Ndfl3Package.payload.sheetB.sources[{}].incomeTypeCode'.format(0)
    name_id4 ='Ndfl3Package.payload.sheetA.sources[{}].taxRate'.format(2)
    name_id5 ='Ndfl3Package.payload.sheetB.sources[{}].incomeDate'.format(0)
    name_id6 ='Ndfl3Package.payload.sheetB.sources[{}].taxDeductionCode'.format(0)
    name_id7 = 'Ndfl3Package.payload.sheetB.sources[{}].taxPaymentDate'.format(0)
    name_id8 = 'Ndfl3Package.payload.sheetB.sources[{}].incomeAmountCurrency'.format(0)
    name_id9 = 'Ndfl3Package.payload.sheetB.sources[{}].paymentAmountCurrency'.format(0)
    name_id10 = 'Ndfl3Package.payload.sheetB.sources[{}].currencyCode'.format(0)
  
    adress='//*[@class="boo form_item form_item__part"]//*[@id="{0}.incomeSourceName"' \
           ' and @id="{0}.incomeSourceName"]'.format(name_id2)
    driver.find_element_by_xpath(adress).send_keys(comp)# имя компании
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
    adress='//*[@id="{}"]//*[@id="react-select-8--value"]/div[1]'.format(name_id)
  
    driver.find_element_by_xpath(adress).click()
    class1='Select-multi-value-wrapper'
    select_contry='react-select-8--value'
    adress='//*[@id="{}"]//*[@class="{}" and @id="{}"]//*[@class="Select-input"]/input'.format(name_id, class1, select_contry)
    driver.find_element_by_xpath(adress).send_keys(country)
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
    driver.execute_script("window.scrollTo(0, 520)")
    payment_type= 'react-select-10--value'
    adress='//*[@id="{}"]//*[@class="{}" and @id="{}"]//*[@class="Select-input"]/input'.format(name_id3, class1, payment_type)
  
    driver.find_element_by_xpath(adress).send_keys("1010 - Дивиденды")# тип выплаты.
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
  
    driver.execute_script("window.scrollTo(0, 420)")
 
    class1='Select-control'
    class2='Select-arrow-zone'
    adress='//*[@id="{0}"]//*[@class="{1}"]/*[@class="{2}"]/*[@class="Select-arrow"]'.format(name_id6, class1, class2)
    driver.find_element_by_xpath(adress).click() # налоговой вычет.
  
    class2='Select-multi-value-wrapper'
    id_name='react-select-14--value'
    adress ='//*[@id="{0}"]//*[@class="{1}"]//*[@class="{2}" and @id="{3}"]//*[@role="combobox"]'\
      .format(name_id6, class1,class2, id_name)
    driver.find_element_by_xpath(adress).send_keys("Не предоставлять вычет")
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
    check(driver)
    class1='IncomesOutsideRFComponent_formFields__1luVK'
    adress='//*[@class="{0}"]//*[@name="{1}" and @id="{1}"]'.format(class1, name_id8)
 
    driver.find_element_by_xpath(adress).send_keys(received)# сколько получили
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
    driver.execute_script("window.scrollTo(0, 460)")
  
    class1='react-datepicker-wrapper'
    class2='react-datepicker__input-container'
    adress='//*[@id="{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id7,class1,class2)
    driver.find_element_by_xpath(adress).click()
    driver.find_element_by_xpath(adress).send_keys(date)# дата уплаты налога
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
  
    id_name='react-select-11--value'
    class1='Select-multi-value-wrapper'
    class2='Select-input'
    adress='//*[@class="help-wrap"]//*[@id="{0}"]//*[@class="{1}" and @id="{2}"]//input'\
      .format(name_id10, class1, id_name, class2) # валюта
    driver.find_element_by_xpath(adress).send_keys("840 - Доллар США")
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
    adress='//*[@name="{0}" and @id="{0}"]'.format(name_id9)
 
    driver.find_element_by_xpath(adress).send_keys(tax_on_dividends)
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
    class1='react-datepicker-wrapper'
    class2='react-datepicker__input-container'
    adress='//*["{0}"]//*[@class="{1}"]//*[@class="{2}"]//input'.format(name_id5,class1,class2)
 
   
    driver.find_element_by_xpath(adress).click()
    driver.find_element_by_xpath(adress).send_keys(date)#Дата получения дохода *
    driver.find_element_by_xpath(adress).send_keys(Keys.RETURN)
 
    adress='//*[@class="form_item"]//*[@class="form-checkbox_text"]'
 
    driver.find_element_by_xpath(adress).click()
    # print(adress)
    # input()
    while 1:
     time.sleep(36)
except Exception as ex:
  print(ex)
finally:
  print("exit")
  driver.close()
  driver.quit()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.08.2021, 12:20
Помогаю со студенческими работами здесь

Автогенерация форм для ввода данных в БД
Здравствуйте! Подскажите, плз, нужно создать кучу похожих формочек для заполнения словарей БД. Возможно ли создать базовую форму, например...

Запись с форм ввода и вывод результата
Здравствуйте, уважаемые программисты, требуется ваша помощь. Постараюсь объяснить все как можно! Вот скриншот моей странички на PHP: ...

Синхронизация полей ввода 2 разных форм
Доброго времени суток, передо мной стоит следующая задача. Главное окно содержит семь полей ввода и кнопку «Show». При нажатии кнопки...

Создание форм для ввода и редактирования данных
Помогите, не как не могу разобраться стоит 2016 офис не могу никак разобраться, как сделать --форму для (исключительно ввода...

Создание БД с поддержкой ввода, редактирования и удаления из форм
Мне необходимо создать БД в phpMyAdmin и с помощью форм предусмотреть ввод, удаление и редактирование данных. Нашел вот этот сайт...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru