<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
1.新建一個link文字,將需要下載的文章連結依次儲存;
2.新建一個.py檔案,將下面的原始碼複製進去;
3.新建一個pic資料夾,用來儲存圖片;
4.執行即可;
sound code
程式碼如下(範例):
import requests from re import findall from bs4 import BeautifulSoup import time import os import sys weixin_title="" weixin_time="" #獲取微信公眾號內容,儲存標題和時間 def get_weixin_html(url): global weixin_time,weixin_title res=requests.get(url) soup=BeautifulSoup(res.text,"html.parser") #獲取標題 temp=soup.find('h1') weixin_title=temp.string.strip() #使用正規表示式獲取時間 # result=findall(r'[0-9]{4}-[0-9]{2}-[0-9]{2}.+:[0-9]{2}',res.text) result=findall(r"(d{4}-d{1,2}-d{1,2})",res.text) weixin_time=result[0] #獲取正文html並修改 content=soup.find(id='js_content') soup2=BeautifulSoup((str(content)),"html.parser") soup2.div['style']='visibility: visible;' html=str(soup2) pattern=r'http[s]?://[a-z.A-Z_0-9/?=-_-]+' result = findall(pattern, html) #將data-src修改為src for url in result: html=html.replace('data-src="'+url+'"','src="'+url+'"') return html #上傳圖片至伺服器 def download_pic(content): pic_path= 'pic/' + str(path)+ '/' if not os.path.exists(pic_path): os.makedirs(pic_path) #使用正規表示式查詢所有需要下載的圖片連結 pattern=r'http[s]?://[a-z.A-Z_0-9/?=-_-]+' pic_list = findall(pattern, content) for index, item in enumerate(pic_list,1): count=1 flag=True pic_url=str(item) while flag and count<=10: try: data=requests.get(pic_url); if pic_url.find('png')>0: file_name = str(index)+'.png' elif pic_url.find('gif')>0: file_name=str(index)+'.gif' else: file_name=str(index)+'.jpg' with open( pic_path + file_name,"wb") as f: f.write(data.content) #將圖片連結替換為本地連結 content = content.replace(pic_url, pic_path + file_name) flag = False print('已下載第' + str(index) +'張圖片.') count += 1 time.sleep(1) except: count+=1 time.sleep(1) if count>10: print("下載出錯:",pic_url) return content def get_link(dir): link = [] with open(dir,'r') as file_to_read: while True: line = file_to_read.readline() if not line: break line = line.strip('n') link.append(line) return link path = 'link.txt' linklist = get_link(path) print(linklist) s = len(linklist) if __name__ == "__main__": #獲取html input_flag=True while input_flag: # for j in range(0,s): # pic = str(j) j = 1 for i in linklist: weixin_url = i path = j j += 1 #weixin_url=input() re=findall(r'http[s]?://mp.weixin.qq.com/s/[0-9a-zA-Z_]+',weixin_url) if len(re)<=0: print("連結有誤,請重新輸入!") else: input_flag=False content=get_weixin_html(weixin_url) content=download_pic(content) #儲存至本地 with open(weixin_title+'.txt','w+',encoding="utf-8") as f: f.write(content) with open(weixin_title+'.html','w+',encoding="utf-8") as f: f.write(content) print() print("標題:《"+weixin_title+"》") print("釋出時間:"+weixin_time)
import re from datetime import datetime test_date = '小明的生日是2016-12-12 14:34,小張的生日是2016-12-21 11:34 .' test_datetime = '小明的生日是2016-12-12 14:34,.小晴的生日是2016-12-21 11:34,好可愛的.' # date mat = re.search(r"(d{4}-d{1,2}-d{1,2})",test_date) print mat.groups() # ('2016-12-12',) print mat.group(0) # 2016-12-12 date_all = re.findall(r"(d{4}-d{1,2}-d{1,2})",test_date) for item in date_all: print item # 2016-12-12 # 2016-12-21 # datetime mat = re.search(r"(d{4}-d{1,2}-d{1,2}sd{1,2}:d{1,2})",test_datetime) print mat.groups() # ('2016-12-12 14:34',) print mat.group(0) # 2016-12-12 14:34 date_all = re.findall(r"(d{4}-d{1,2}-d{1,2}sd{1,2}:d{1,2})",test_datetime) for item in date_all: print item # 2016-12-12 14:34 # 2016-12-21 11:34 ## 有效時間 # 如這樣的日期2016-12-35也可以匹配到.測試如下. test_err_date = '如這樣的日期2016-12-35也可以匹配到.測試如下.' print re.search(r"(d{4}-d{1,2}-d{1,2})",test_err_date).group(0) # 2016-12-35 # 可以加個判斷 def validate(date_text): try: if date_text != datetime.strptime(date_text, "%Y-%m-%d").strftime('%Y-%m-%d'): raise ValueError return True except ValueError: # raise ValueError("錯誤是日期格式或日期,格式是年-月-日") return False print validate(re.search(r"(d{4}-d{1,2}-d{1,2})",test_err_date).group(0)) # false # 其他格式匹配. 如2016-12-24與2016/12/24的日期格式. date_reg_exp = re.compile('d{4}[-/]d{2}[-/]d{2}') test_str= """ 平安夜聖誕節2016-12-24的日子與去年2015/12/24的是有不同哦. """ # 根據正則查詢所有日期並返回 matches_list=date_reg_exp.findall(test_str) # 列出並列印匹配的日期 for match in matches_list: print match # 2016-12-24 # 2015/12/24
以上就是Python實現快速儲存微信公眾號文章中的圖片的詳細內容,更多關於Python儲存文章圖片的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45