Python實現(xiàn)快速保存微信公眾號文章中的圖片
更新時間:2022年06月22日 15:12:16 作者:用余生去守護
這篇文章主要為大家詳細介紹了如何利用Python語言實現(xiàn)快速保存微信公眾號文章中的圖片,文中的示例代碼講解詳細,感興趣的可以嘗試一下
一、實現(xiàn)效果(以槿泉壁紙為例)




二、實現(xiàn)過程
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=""
#獲取微信公眾號內(nèi)容,保存標題和時間
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("發(fā)布時間:"+weixin_time)
四、Python正則表達式匹配日期與時間
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}\s\d{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}\s\d{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= """
平安夜圣誕節(jié)2016-12-24的日子與去年2015/12/24的是有不同哦.
"""
# 根據(jù)正則查找所有日期并返回
matches_list=date_reg_exp.findall(test_str)
# 列出并打印匹配的日期
for match in matches_list:
print match
# 2016-12-24
# 2015/12/24
以上就是Python實現(xiàn)快速保存微信公眾號文章中的圖片的詳細內(nèi)容,更多關于Python保存文章圖片的資料請關注腳本之家其它相關文章!
相關文章
基于python神經(jīng)卷積網(wǎng)絡的人臉識別
這篇文章主要為大家詳細介紹了基于python神經(jīng)卷積網(wǎng)絡的人臉識別,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05
python基于pygame實現(xiàn)響應游戲中事件的方法(附源碼)
這篇文章主要介紹了python基于pygame實現(xiàn)響應游戲中事件的方法,實例分析了Python基于pygame針對鍵盤及鼠標事件的響應方法,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
Django中的DateTimeField和DateField實現(xiàn)
這篇文章主要介紹了Django中的DateTimeField和DateField實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02

