Мне удалось напечатать и загрузить pdf с помощью моего скрипта, описанного выше, но у меня возникла проблема, как распечатать / скачать pdf с помощью selenium python в режиме LANDSCAPE.
Я пытаюсь использовать pdfkit с "fromstring" с selenium "driver.getsource", но портретный режим не очень хороший результат, и, наконец, я решил использовать PDF для печати из chromedriver, и мне удалось создать PDF-файл, который я хочу с хороший результат, но застрял только в портретном режиме. Несмотря на то, что мне нужно в ландшафтном режиме
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
import time
import pdfkit
import json
import os
curr_dir = os.getcwd()
download_path = os.path.join(curr_dir, 'dl')
appState = {
"recentDestinations": [
{
"id": "Save as PDF",
"origin": "local"
}
],
"selectedDestinationId": "Save as PDF",
"version": 2,
}
profile = {
'printing.print_preview_sticky_settings.appState': json.dumps(appState),
'savefile.default_directory': download_path,
}
chrome_options = webdriver.ChromeOptions()
chrome_options.add_experimental_option('prefs', profile)
chrome_options.add_argument('--kiosk-printing')
driver = webdriver.Chrome("D:\\master\\chromedriver\\2.45\\chromedriver.exe",
chrome_options=chrome_options)
URL = "taget site"
def site_login():
driver.get(URL)
driver.find_element_by_id('username').send_keys('username')
driver.find_element_by_id ('password').send_keys('pass')
driver.find_element_by_name('login').click()
def get_abc():
driver.get('https://targetsite/abc')
driver.find_element_by_name('year_id_combo')
s1 = Select(driver.find_element_by_name('year_id_combo'))
s1.select_by_visible_text('summer')
select_box = driver.find_element_by_name('course_id')
mk = [x for x in select_box.find_elements_by_tag_name("option")]
course_name = mk[2].text
course_name = course_name.replace(' ', '_')
index_mk = course_name.index('|')
course_name = course_name[:index_mk]
s2 = Select(driver.find_element_by_name('course_id'))
s2.select_by_value(mk[2].get_attribute('value'))
s3 = Select(driver.find_element_by_name('class'))
list_class = driver.find_element_by_name('class')
class = [x for x in list_class.find_elements_by_tag_name("option")]
s3.select_by_value(class[1].get_attribute('value'))
# multiple windows handle
main_window_handle = None
while not main_window_handle:
main_window_handle = driver.current_window_handle
driver.find_element_by_xpath( '/html/body/div[3]/div[2]/div/div/div[1]/div[1]/div/div[2]/div[2]/div/input[1]').click()
print_window_handle = None
while not print_window_handle:
for handle in driver.window_handles:
if handle != main_window_handle:
print_window_handle = handle
break
driver.switch_to.window(print_window_handle)
webdriver.ActionChains(driver).send_keys(Keys.ESCAPE).perform()
driver.execute_script(
"document.title='{}';window.print();".format(course_name)
)
def logout_system():
driver.find_element_by_xpath('//a[normalize-
space(text())="Logout"]').click()
def close():
driver.close()
driver.quit()
site_login()
time.sleep(5)
get_abc()
time.sleep(70)
logout_system()
time.sleep(5)
close()
Я ожидаю, что результат будет напечатан в режиме PDF в альбомной ориентации, но я не знаю, как сделать так, чтобы в этой ситуации он был в альбомной ориентации, результатом теперь является только портретный PDF.