from bs4 import * from pyquery import PyQuery as pq from selenium import webdriver from selenium.webdriver.common.keys import Keys import os import requests import time import threading import logging import random browser = webdriver.Chrome() url = 'https://so.gushiwen.org/shiwenv_ee16df5673bc.aspx' browser.get(url) js = "a_=document.getElementsByTagName('a');le=a_.length;for(i=0;i<le;i++){if(a_[i].text=='展開閱讀全文 ∨'){try{a_[i].click()}catch(err){console.log(err)}}}" try: browser.execute_script(js) except Exception as e: print(e) ck_l_ori_len = len(browser.find_elements_by_link_text('展開閱讀全文 ∨')) ck_l_ori_ok = 0 try: for isc in range(100): if ck_l_ori_ok == ck_l_ori_len: break time.sleep(1) js = 'window.scrollTo(0,document.body.scrollHeight)' js = 'window.scrollTo(0,100*{})'.format(isc) browser.execute_script(js) ck_l = browser.find_elements_by_link_text('展開閱讀全文 ∨') for i in ck_l: try: i.click() ck_l_ori_ok += 1 except Exception as e: print(e) except Exception as e: print('window.scrollTo-->', e) doc = pq(browser.page_source) pq_r_d = {'xmlns="http://www.w3.org/1999/xhtml"': ''} r_k, r_v = 'xmlns="http://www.w3.org/1999/xhtml"', '' article_ = doc('.left>:nth-child(2).sons>.cont>.contson').html().replace(r_k, r_v) title_d = {'h1': doc('.left>:nth-child(2).sons>.cont>:nth-child(2)').html().replace(r_k, r_v)} author_d = {'h3': doc('.left>:nth-child(2).sons>.cont>:nth-child(3)').text()} translation_ = doc('.left>:nth-child(4)>.contyishang>:nth-child(2)').html().replace(r_k, r_v) explanation_ = doc('.left>:nth-child(4)>.contyishang>:nth-child(3)').html().replace(r_k, r_v) refer_ = doc('.left>:nth-child(4)>.cankao').html().replace(r_k, r_v) author_img_url = doc('.left>.sonspic>.cont>.divimg>:nth-child(1)').html().split('src="')[-1].split('"')[0] k = 'h1' v = title_d[k] db_html = '<{}>{}</{}>'.format(k, v, k) k = 'h3' v = author_d[k] db_html = '{}<{}>{}</{}>'.format(db_html, k, v, k) db_html = '{}{}'.format(db_html, '<br><img src="{}" ><br>'.format(author_img_url)) l = [db_html, article_, explanation_, translation_, refer_] db_html = '<br><br>'.join(l) rp_s_l = ['<a href=', '<a href=', '<a title=', '<a title='] for rp_s in rp_s_l: img_n = db_html.count(rp_s) for i in range(img_n): p1 = db_html.index(rp_s, 0) tmp = '{}{}'.format(db_html[0:p1].replace('>', 'X'), db_html[p1 + 1:]) p2 = tmp.index('>') db_html = '{}{}{}'.format(db_html[0:p1], '', db_html[p2 + 1:]) f_url_l = ['https://www.toutiao.com/a6514526304476332552/', 'https://www.toutiao.com/a6514778729951003150/'] f_url_l += ['https://www.toutiao.com/a6514216125151052291/', 'https://www.toutiao.com/a6512315164463727111/'] f_url_l_a = f_url_l[int(time.time()) % len(f_url_l)] # browser = webdriver.Chrome() js = 'window.location.href="{}";'.format(f_url_l_a) browser.execute_script(js) # browser.get(f_url_l_a) time.sleep(random.randint(10, 20)) js = 'window.location.href="https://sso.toutiao.com/login/";' js = 'window.location.href="https://sso.toutiao.com/login/?service=https://mp.toutiao.com/sso_confirm/?redirect_url=/";' browser.execute_script(js) time.sleep(random.randint(10, 20)) start_time = time.strftime('%Y%m%d_%H%M%S', time.localtime(time.time())) os_sep = os.sep this_file_abspath, this_file_name = os.path.dirname(os.path.abspath(__file__)), os.path.abspath(__file__).split(os_sep)[ -1] logf = this_file_name + '.log' try: logging.basicConfig(level=logging.INFO, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s[thread:%(thread)d][process:%(process)d]', datefmt='%a, %d %b %Y %H:%M:%S', filename=logf, filemode='a') except Exception as e: s = '%s%s%s' % ('logging.basicConfig EXCEPTION ', time.strftime('%Y%m%d_%H%M%S', time.localtime(time.time())), e) with open(logf, 'a') as fo: fo.write(s) print(s) os._exit(4002) logging.info('START') img_url = 'https://s3.pstatp.com/toutiao/static/img/logo.201f80d.png' img_dir = 'C:\\Users\\sas\\PycharmProjects\\py_win_to_unix\\crontab_chk_url\\personas\\trunk\\plugins\\spider\\dl_img_tmp\\' import random def spider_webimg_dl_return_local_img_path(img_dir, img_url, local_default='default.DONOT_REMOVE.png'): r = '%s%s' % (img_dir, local_default) try: bytes = requests.get(img_url)._content # r = '%s%s%s%s%s' % ( # img_dir, time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())), str(threading.get_ident()), # img_url.replace('/', '_xl_').replace(':', '_fxl_').replace('?', '_fxlquestion_').replace('=', # '_fxlequal_').replace( # '&', '_fxland_'), '.png') r = '%s%s%s%s%s' % ( img_dir, time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())), str(threading.get_ident()), random.randint(1234, 9876), '.png') if bytes != 0: with open(r, 'wb')as f: f.write(bytes) except Exception as e: print(e) return r d = {} d['title'] = '《{}》{}'.format(title_d['h1'], author_d['h3'])[0:30] d['content'] = db_html ac_type, ac = 'qq', {} ac['u'], ac['p'] = '2783', 'w3q' if ac_type == 'qq': myid, mypwd = ac['u'], ac['p'] xp = '/html/body/div/div/div[2]/div/div/div/ul/li[3]' xp = '/html/body/div/div/div[2]/div/div/div/ul/li[2]' browser.find_element_by_xpath(xp).click() time.sleep(10) js = '%s%s%s' % ('document.getElementById("u").value="', myid, '"') browser.execute_script(js) js = '%s%s%s' % ('document.getElementById("p").value="', mypwd, '"') browser.execute_script(js) time.sleep(random.randint(5, 15)) xp_newpage = '//*[@id="go"]' browser.find_element_by_xpath(xp_newpage).click() time.sleep(random.randint(10, 20)) browser.refresh() js = 'window.location.href="https://www.toutiao.com/";' browser.execute_script(js) browser.refresh() time.sleep(6) js = 'window.location.href="https://mp.toutiao.com/profile_v2/publish/";' js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/publish";' browser.execute_script(js) time.sleep(6) dbhtml_str, pgc_img_url_l = d['content'], [] myhtml = 'D:\\myhtml\\{}tmp.html'.format(random.randint(123, 999)) with open(myhtml, 'w', encoding='utf-8') as fw: fw.write(dbhtml_str) with open(myhtml, 'r', encoding='utf-8') as myhtml_o: bs = BeautifulSoup(myhtml_o, 'html.parser') pgc_img_url_l = [i.attrs['src'] for i in bs.find_all('img')] js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/resource-manager";' browser.execute_script(js) time.sleep(2) xp = '//*[@id="graphic"]/div/div/div[3]/div/div[1]/div[3]/div/input' upload = browser.find_element_by_xpath(xp) for img_url in pgc_img_url_l: local_img_path = spider_webimg_dl_return_local_img_path(img_dir, img_url) upload.send_keys(local_img_path) time.sleep(10 * len(pgc_img_url_l)) pgc_img_url_l_toutiao = [i.find_element_by_tag_name('img').get_attribute('src') for i in browser.find_elements_by_class_name('pic')][0:len(pgc_img_url_l)] pgc_img_url_l_toutiao = [i for i in sorted(pgc_img_url_l_toutiao, reverse=True)] ''' <img onload="editor.fireEvent('contentchange')" src="https://p1.pstatp.com/large/pgc-image/15238623686755f9e3c409a" _src="https://p1.pstatp.com/large/pgc-image/15238623686755f9e3c409a" alt="pgc-image/15238623686755f9e3c409a" buttonadded="true"> ''' dbhtml_str_ = dbhtml_str img_n = dbhtml_str_.count('<img') s = '<img onload="editor.fireEvent(\'contentchange\')" src="https://p1.pstatp.com/large/pgc-image/TTimgCode" _src="https://p1.pstatp.com/large/pgc-image/TTimgCode" alt="pgc-image/TTimgCode" buttonadded="true">' s = '<img onload="editor.fireEvent(\'contentchange\')" src="https://p1.pstatp.com/large/pgc-image/TTimgCode" _src="https://p1.pstatp.com/large/pgc-image/TTimgCode" alt="pgc-image/TTimgCode" buttonadded="true">' # s = "<img onload='editor.fireEvent(\'contentchange\')' src='https://p1.pstatp.com/large/pgc-image/TTimgCode' _src='https://p1.pstatp.com/large/pgc-image/TTimgCode' alt='pgc-image/TTimgCode' buttonadded='true'>" ss = '' l = pgc_img_url_l_toutiao for i in range(img_n): if i == 0: p1 = dbhtml_str.index('<img ', 0) else: p1 = dbhtml_str.index('<img ', p1 + 3) tmp = '{}{}'.format(dbhtml_str[0:p1].replace('>', 'X'), dbhtml_str[p1:]) p2 = tmp.index('>') ss = s.replace('TTimgCode', l[0].split('/')[-1]) dbhtml_str = '{}{}{}'.format(dbhtml_str[0:p1], ss, dbhtml_str[p2 + 1:]) del l[0] print('-----------------') print(dbhtml_str) time.sleep(2) js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/publish";' browser.execute_script(js) time.sleep(6) xp_newpage = '//*[@id="title"]' mytxt = d['title'] browser.find_element_by_xpath(xp_newpage).send_keys(Keys.SPACE) browser.find_element_by_xpath(xp_newpage).send_keys(mytxt) time.sleep(2) xp = '//*[@id="edui18_body"]/div[1]' # //*[@id="edui18_body"]/div[1] browser.find_element_by_xpath(xp).click() time.sleep(2) xp = '//*[@id="images"]/div[1]/div/span' browser.find_element_by_xpath(xp).click() time.sleep(3) ''' 'it=document.getElementById("ueditor_0").contentWindow.document.getElementsByTagName("body")[0];it.innerHTML="{}"'.format(dbhtml_str.replace('onload="editor.fireEvent(\'contentchange\')"','').replace('"',"'").replace('\n','')) ''' # 結合瀏覽器控制檯,拼接符合語法的js字符串 r_d = {'onload="editor.fireEvent(\'contentchange\')"': '', '"': "'", '\n': ''} dbhtml_str_py_js = dbhtml_str for k in r_d: dbhtml_str_py_js = dbhtml_str_py_js.replace(k, r_d[k]) dbhtml_str_py_js = dbhtml_str_py_js.replace('nbsp;', ' ') js = 'document.getElementById("ueditor_0").contentWindow.document.getElementsByTagName("body")[0].innerHTML="{}"'.format( dbhtml_str_py_js) browser.execute_script(js) # 自動 # Message: unknown error: Element is not clickable at point (589, 952) try: for isc in range(2): time.sleep(1) js = 'window.scrollTo(0,document.body.scrollHeight)' browser.execute_script(js) except Exception as e: print('window.scrollTo-->', e) time.sleep(10) try: xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[1]/div[2]/div/div/div[1]/div/label[3]/span' browser.find_element_by_xpath(xp).click() time.sleep(1) except Exception as e: print(e) time.sleep(2) # 不投放廣告 xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[2]/div[2]/div[1]/label[2]/span' # 投放廣告 xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[2]/div[2]/div[1]/label[1]/span' browser.find_element_by_xpath(xp).click() time.sleep(1) # 存草稿 xp = '//*[@id="graphic"]/div/div/div[2]/div[3]/div[2]/div[2]' # 發佈 xp = '//*[@id="graphic"]/div/div/div[2]/div[3]/div[2]/div[1]' browser.find_element_by_xpath(xp).click() time.sleep(random.randint(20, 30)) js = 'window.location.href="https://www.toutiao.com/"' browser.execute_script(js) try: browser.quit() except Exception as e1: print(e1) logging.exception(e1)
<h1>秋夜讀書每以二鼓盡爲節</h1><h3>宋代 : 陸游</h3><br><img onload="editor.fireEvent('contentchange')" src="https://p1.pstatp.com/large/pgc-image/15246284315719a928e33a1" _src="https://p1.pstatp.com/large/pgc-image/15246284315719a928e33a1" alt="pgc-image/15246284315719a928e33a1" buttonadded="true"><br><br><br> 腐儒碌碌嘆無奇,獨喜遺編不我欺。<br />白髮無情侵老境,青燈有味似兒時。<br />高梧策策傳寒意,疊鼓鼕鼕迫睡期。<br />秋夜漸長飢做祟,一杯山藥進瓊糜。 <br><br><strong >註釋<br /></strong>以二鼓盡爲節:指讀書讀到二更天才中止。二鼓,指更鼓報過二更。<br />腐儒:做者自稱。<br />碌碌:平庸,無所做爲。<br />遺編:遺留後世的著做,泛指古代典籍。<br />不我欺:並不欺騙我。<br />策策:象聲詞,指風搖動樹葉發出的響聲。<br />疊鼓:輕輕擊鼓,指更鼓。<br />鼕鼕:象聲詞,指鼓聲。<br />迫睡期:催人睡覺。<br />做祟:暗中搗鬼,形容夜深了尚未睡覺,肚子餓了。<br />瓊糜:像瓊漿同樣甘美的粥。糜,粥。>▲</a><br><br><strong >譯文<br /></strong>我這個迂腐的儒生,可嘆一輩子碌碌無奇,卻只愛前人留下來的著做,從不將我欺騙。<br />白髮無情地爬上頭頂,漸漸地進入老年,讀書的青燈卻依舊像兒時那樣親切有味。<br />高大的梧桐策策做響,傳來一陣陣寒意,讀書興致正濃,忽聽更鼓鼕鼕催人入睡。<br />秋夜漫漫,飢腸轆轆,再也難以讀下去,喝杯山藥煮成的薯粥,賽過那佳餚美味。<br><br> <p style=" color:#999999;margin:0px; font-size:12px;line-height:160%;">參考資料:</p> <div style="clear:both; float:left;color:#999999; font-size:12px; width:630px; margin-top:4px;"> <span style="width:20px; float:left;">一、</span> <span style="width:610px; float:left;">劉揚忠注評.陸游詩詞選評:三秦出版社,2008.2:9-10</span> </div> <div style="clear:both; float:left;color:#999999; font-size:12px; width:630px; margin-top:4px;"> <span style="width:20px; float:left;">二、</span> <span style="width:610px; float:left;">(宋)陸游著,王水照,高克勤選注.陸游選集:人民文學出版社,1997年11月:16</span> </div> <div style="clear:both; float:left;color:#999999; font-size:12px; width:630px; margin-top:4px;"> <span style="width:20px; float:left;">三、</span> <span style="width:610px; float:left;">鄧建烈主編.高中文言文精譯精講精練 高二:上海交通大學出版社,2006.06:35</span> </div>
from bs4 import * from pyquery import PyQuery as pq from selenium import webdriver from selenium.webdriver.common.keys import Keys import os import requests import time import threading import logging import random start_time = time.strftime('%Y%m%d_%H%M%S', time.localtime(time.time())) os_sep = os.sep this_file_abspath, this_file_name = os.path.dirname(os.path.abspath(__file__)), os.path.abspath(__file__).split(os_sep)[ -1] logf = this_file_name + '.log' try: logging.basicConfig(level=logging.INFO, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s[thread:%(thread)d][process:%(process)d]', datefmt='%a, %d %b %Y %H:%M:%S', filename=logf, filemode='a') except Exception as e: s = '%s%s%s' % ('logging.basicConfig EXCEPTION ', time.strftime('%Y%m%d_%H%M%S', time.localtime(time.time())), e) with open(logf, 'a') as fo: fo.write(s) print(s) os._exit(4002) logging.info('START') img_url = 'https://s3.pstatp.com/toutiao/static/img/logo.201f80d.png' img_dir = 'C:\\Users\\sas\\PycharmProjects\\py_win_to_unix\\crontab_chk_url\\personas\\trunk\\plugins\\spider\\dl_img_tmp\\' import random def spider_webimg_dl_return_local_img_path(img_dir, img_url, local_default='default.DONOT_REMOVE.png'): r = '%s%s' % (img_dir, local_default) try: bytes = requests.get(img_url)._content # r = '%s%s%s%s%s' % ( # img_dir, time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())), str(threading.get_ident()), # img_url.replace('/', '_xl_').replace(':', '_fxl_').replace('?', '_fxlquestion_').replace('=', # '_fxlequal_').replace( # '&', '_fxland_'), '.png') r = '%s%s%s%s%s' % ( img_dir, time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())), str(threading.get_ident()), random.randint(1234, 9876), '.png') if bytes != 0: with open(r, 'wb')as f: f.write(bytes) except Exception as e: print(e) return r browser = webdriver.Chrome() url = 'https://so.gushiwen.org/shiwenv_ee16df5673bc.aspx' browser.get(url) f_url_l = ['https://www.toutiao.com/a6514526304476332552/', 'https://www.toutiao.com/a6514778729951003150/'] f_url_l += ['https://www.toutiao.com/a6514216125151052291/', 'https://www.toutiao.com/a6512315164463727111/'] f_url_l_a = f_url_l[int(time.time()) % len(f_url_l)] # browser = webdriver.Chrome() js = 'window.location.href="{}";'.format(f_url_l_a) browser.execute_script(js) # browser.get(f_url_l_a) time.sleep(random.randint(10, 20)) js = 'window.location.href="https://sso.toutiao.com/login/";' js = 'window.location.href="https://sso.toutiao.com/login/?service=https://mp.toutiao.com/sso_confirm/?redirect_url=/";' browser.execute_script(js) time.sleep(random.randint(10, 20)) ac_type, ac = 'qq', {} ac['u'], ac['p'] = '344', 'gregr' if ac_type == 'qq': myid, mypwd = ac['u'], ac['p'] xp = '/html/body/div/div/div[2]/div/div/div/ul/li[3]' xp = '/html/body/div/div/div[2]/div/div/div/ul/li[2]' browser.find_element_by_xpath(xp).click() time.sleep(10) js = '%s%s%s' % ('document.getElementById("u").value="', myid, '"') browser.execute_script(js) js = '%s%s%s' % ('document.getElementById("p").value="', mypwd, '"') browser.execute_script(js) time.sleep(random.randint(5, 15)) xp_newpage = '//*[@id="go"]' browser.find_element_by_xpath(xp_newpage).click() time.sleep(random.randint(10, 20)) browser.refresh() with open('myurl.txt', 'r') as fr: for url in fr: url = url.replace('\n', '') try: # url = 'https://so.gushiwen.org/shiwenv_ee16df5673bc.aspx' # browser.get(url) js = 'window.location.href="{}";'.format(url) browser.execute_script(js) js = "a_=document.getElementsByTagName('a');le=a_.length;for(i=0;i<le;i++){if(a_[i].text=='展開閱讀全文 ∨'){try{a_[i].click()}catch(err){console.log(err)}}}" try: browser.execute_script(js) except Exception as e: print(e) ck_l_ori_len = len(browser.find_elements_by_link_text('展開閱讀全文 ∨')) ck_l_ori_ok = 0 try: for isc in range(100): if ck_l_ori_ok == ck_l_ori_len: break time.sleep(1) js = 'window.scrollTo(0,document.body.scrollHeight)' js = 'window.scrollTo(0,100*{})'.format(isc) browser.execute_script(js) ck_l = browser.find_elements_by_link_text('展開閱讀全文 ∨') for i in ck_l: try: i.click() ck_l_ori_ok += 1 except Exception as e: print(e) except Exception as e: print('window.scrollTo-->', e) doc = pq(browser.page_source) pq_r_d = {'xmlns="http://www.w3.org/1999/xhtml"': ''} r_k, r_v = 'xmlns="http://www.w3.org/1999/xhtml"', '' article_ = doc('.left>:nth-child(2).sons>.cont>.contson').html().replace(r_k, r_v) title_d = {'h1': doc('.left>:nth-child(2).sons>.cont>:nth-child(2)').html().replace(r_k, r_v)} author_d = {'h3': doc('.left>:nth-child(2).sons>.cont>:nth-child(3)').text()} translation_ = doc('.left>:nth-child(4)>.contyishang>:nth-child(2)').html().replace(r_k, r_v) explanation_ = doc('.left>:nth-child(4)>.contyishang>:nth-child(3)').html().replace(r_k, r_v) refer_ = doc('.left>:nth-child(4)>.cankao').html().replace(r_k, r_v) author_img_url = doc('.left>.sonspic>.cont>.divimg>:nth-child(1)').html().split('src="')[-1].split('"')[0] k = 'h1' v = title_d[k] db_html = '<{}>{}</{}>'.format(k, v, k) k = 'h3' v = author_d[k] db_html = '{}<{}>{}</{}>'.format(db_html, k, v, k) db_html = '{}{}'.format(db_html, '<br><img src="{}" ><br>'.format(author_img_url)) l = [db_html, article_, explanation_, translation_, refer_] db_html = '<br><br>'.join(l) rp_s_l = ['<a href=', '<a href=', '<a title=', '<a title='] for rp_s in rp_s_l: img_n = db_html.count(rp_s) for i in range(img_n): p1 = db_html.index(rp_s, 0) tmp = '{}{}'.format(db_html[0:p1].replace('>', 'X'), db_html[p1 + 1:]) p2 = tmp.index('>') db_html = '{}{}{}'.format(db_html[0:p1], '', db_html[p2 + 1:]) d = {} d['title'] = '《{}》{}'.format(title_d['h1'], author_d['h3'])[0:30] d['content'] = db_html js = 'window.location.href="https://mp.toutiao.com/profile_v2/publish/";' js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/publish";' browser.execute_script(js) time.sleep(6) dbhtml_str, pgc_img_url_l = d['content'], [] myhtml = 'D:\\myhtml\\{}tmp.html'.format(random.randint(123, 999)) with open(myhtml, 'w', encoding='utf-8') as fw: fw.write(dbhtml_str) with open(myhtml, 'r', encoding='utf-8') as myhtml_o: bs = BeautifulSoup(myhtml_o, 'html.parser') pgc_img_url_l = [i.attrs['src'] for i in bs.find_all('img')] js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/resource-manager";' browser.execute_script(js) time.sleep(2) xp = '//*[@id="graphic"]/div/div/div[3]/div/div[1]/div[3]/div/input' upload = browser.find_element_by_xpath(xp) for img_url in pgc_img_url_l: local_img_path = spider_webimg_dl_return_local_img_path(img_dir, img_url) upload.send_keys(local_img_path) time.sleep(10 * len(pgc_img_url_l)) pgc_img_url_l_toutiao = [i.find_element_by_tag_name('img').get_attribute('src') for i in browser.find_elements_by_class_name('pic')][0:len(pgc_img_url_l)] pgc_img_url_l_toutiao = [i for i in sorted(pgc_img_url_l_toutiao, reverse=True)] ''' <img onload="editor.fireEvent('contentchange')" src="https://p1.pstatp.com/large/pgc-image/15238623686755f9e3c409a" _src="https://p1.pstatp.com/large/pgc-image/15238623686755f9e3c409a" alt="pgc-image/15238623686755f9e3c409a" buttonadded="true"> ''' dbhtml_str_ = dbhtml_str img_n = dbhtml_str_.count('<img') s = '<img onload="editor.fireEvent(\'contentchange\')" src="https://p1.pstatp.com/large/pgc-image/TTimgCode" _src="https://p1.pstatp.com/large/pgc-image/TTimgCode" alt="pgc-image/TTimgCode" buttonadded="true">' s = '<img onload="editor.fireEvent(\'contentchange\')" src="https://p1.pstatp.com/large/pgc-image/TTimgCode" _src="https://p1.pstatp.com/large/pgc-image/TTimgCode" alt="pgc-image/TTimgCode" buttonadded="true">' # s = "<img onload='editor.fireEvent(\'contentchange\')' src='https://p1.pstatp.com/large/pgc-image/TTimgCode' _src='https://p1.pstatp.com/large/pgc-image/TTimgCode' alt='pgc-image/TTimgCode' buttonadded='true'>" ss = '' l = pgc_img_url_l_toutiao for i in range(img_n): if i == 0: p1 = dbhtml_str.index('<img ', 0) else: p1 = dbhtml_str.index('<img ', p1 + 3) tmp = '{}{}'.format(dbhtml_str[0:p1].replace('>', 'X'), dbhtml_str[p1:]) p2 = tmp.index('>') ss = s.replace('TTimgCode', l[0].split('/')[-1]) dbhtml_str = '{}{}{}'.format(dbhtml_str[0:p1], ss, dbhtml_str[p2 + 1:]) del l[0] print('-----------------') print(dbhtml_str) time.sleep(2) js = 'window.location.href="https://mp.toutiao.com/profile_v3/graphic/publish";' browser.execute_script(js) time.sleep(6) xp_newpage = '//*[@id="title"]' mytxt = d['title'] browser.find_element_by_xpath(xp_newpage).send_keys(Keys.SPACE) browser.find_element_by_xpath(xp_newpage).send_keys(mytxt) time.sleep(2) xp = '//*[@id="edui18_body"]/div[1]' # //*[@id="edui18_body"]/div[1] browser.find_element_by_xpath(xp).click() time.sleep(2) xp = '//*[@id="images"]/div[1]/div/span' browser.find_element_by_xpath(xp).click() time.sleep(3) ''' 'it=document.getElementById("ueditor_0").contentWindow.document.getElementsByTagName("body")[0];it.innerHTML="{}"'.format(dbhtml_str.replace('onload="editor.fireEvent(\'contentchange\')"','').replace('"',"'").replace('\n','')) ''' # 結合瀏覽器控制檯,拼接符合語法的js字符串 r_d = {'onload="editor.fireEvent(\'contentchange\')"': '', '"': "'", '\n': ''} dbhtml_str_py_js = dbhtml_str for k in r_d: dbhtml_str_py_js = dbhtml_str_py_js.replace(k, r_d[k]) dbhtml_str_py_js = dbhtml_str_py_js.replace('nbsp;', ' ') js = 'document.getElementById("ueditor_0").contentWindow.document.getElementsByTagName("body")[0].innerHTML="{}"'.format( dbhtml_str_py_js) browser.execute_script(js) # 自動 # Message: unknown error: Element is not clickable at point (589, 952) try: for isc in range(2): time.sleep(1) js = 'window.scrollTo(0,document.body.scrollHeight)' browser.execute_script(js) except Exception as e: print('window.scrollTo-->', e) time.sleep(10) try: xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[1]/div[2]/div/div/div[1]/div/label[3]/span' browser.find_element_by_xpath(xp).click() time.sleep(1) except Exception as e: print(e) time.sleep(2) # 不投放廣告 xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[2]/div[2]/div[1]/label[2]/span' # 投放廣告 xp = '//*[@id="graphic"]/div/div/div[2]/div[2]/div[2]/div[2]/div[1]/label[1]/span' browser.find_element_by_xpath(xp).click() time.sleep(1) # 存草稿 xp = '//*[@id="graphic"]/div/div/div[2]/div[3]/div[2]/div[2]' # 發佈 xp = '//*[@id="graphic"]/div/div/div[2]/div[3]/div[2]/div[1]' browser.find_element_by_xpath(xp).click() time.sleep(random.randint(10, 20)) js = 'window.location.href="https://www.toutiao.com/"' browser.execute_script(js) except Exception as e: print(e) logging.exception(e) try: browser.quit() except Exception as e1: print(e1) logging.exception(e1)
重複校驗的實時性 javascript