中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

網(wǎng)站上上傳圖片 怎么做社交網(wǎng)絡(luò)推廣方法

網(wǎng)站上上傳圖片 怎么做,社交網(wǎng)絡(luò)推廣方法,wordpress選擇虛擬云主機(jī),企業(yè)推廣策劃公司文章目錄 完整代碼一、上傳資源二、替換 MD 中的引用文件為在線鏈接參考 完整代碼 完整代碼由兩個(gè)文件組成,upload.py 和 main.py,放在同一目錄下運(yùn)行 main.py 就好! # upload.py import requests class UploadPic: def __init__(self, c…

文章目錄

    • 完整代碼
    • 一、上傳資源
    • 二、替換 MD 中的引用文件為在線鏈接
    • 參考

完整代碼

完整代碼由兩個(gè)文件組成,upload.pymain.py,放在同一目錄下運(yùn)行 main.py 就好!

# upload.py
import requests  class UploadPic:  def __init__(self, cookie):  self.cookie = cookie  # 解析  self.file_path = ''  self.img_type = ''  # 兩個(gè)請求體  self.upload_data = {}  self.csdn_data = {}  self.output_url = ''  def _get_file(self, file_path):  with open(file_path, mode='rb') as f:  binary_data = f.read()  return binary_data  def _upload_request(self):  headers = {  'accept': '*/*',  'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'content-type': 'application/json',  'cookie': self.cookie,  'origin': 'https://editor.csdn.net',  'priority': 'u=1, i',  'referer': 'https://editor.csdn.net/',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  'sec-fetch-dest': 'empty',  'sec-fetch-mode': 'cors',  'sec-fetch-site': 'same-site',  'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  }  params = {  'type': 'blog',  'rtype': 'markdown',  'x-image-template': '',  'x-image-app': 'direct_blog',  'x-image-dir': 'direct',  'x-image-suffix': self.img_type,  }  url = 'https://imgservice.csdn.net/direct/v1.0/image/upload'  response = requests.get(url, params=params, headers=headers)  try:  self.upload_data = response.json()  except Exception as e:  return e  def _csdn_request(self):  headers = {  'Accept': 'application/json, text/javascript, */*; q=0.01',  'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'Connection': 'keep-alive',  'Origin': 'https://editor.csdn.net',  'Referer': 'https://editor.csdn.net/',  'Sec-Fetch-Dest': 'empty',  'Sec-Fetch-Mode': 'cors',  'Sec-Fetch-Site': 'cross-site',  'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  }  files = {  'key': (None, self.upload_data['data']['filePath']),  'policy': (None, self.upload_data['data']['policy']),  'OSSAccessKeyId': (None, self.upload_data['data']['accessId']),  'success_action_status': (None, '200'),  'signature': (None, self.upload_data['data']['signature']),  'callback': (None, self.upload_data['data']['callbackUrl']),  'file': (f'image.{self.img_type}', self._get_file(self.file_path), f'image/{self.img_type}'),  }  url = 'https://csdn-img-blog.oss-cn-beijing.aliyuncs.com/'  response = requests.post(url, headers=headers, files=files)  try:  self.csdn_data = response.json()  self.output_url = self.csdn_data['data']['imageUrl']  except Exception as e:  return e  def upload_image(self, file_path):  self.file_path = file_path  self.img_type = self.file_path.split('.')[-1]  exception_1 = self._upload_request()  assert exception_1 is None, exception_1  exception_2 = self._csdn_request()  assert exception_2 is None, exception_2  return self.output_url  if __name__ == '__main__':  cookie = '' # 輸入你的cookie  upload = UploadPic(cookie)  output_url = upload.upload_image('')  #輸入你需要上傳的文件位置print(output_url)
# main.py
import os  
import re  
from pathlib import Path  
from rich.progress import track  
from upload import UploadPic  class CSDNTransform:  def __init__(self, upload:UploadPic, file_path, walk_path='C:/Users/Administrator/Documents/Obsidian Vault/'):  self.upload = upload  self.file_path = file_path  self.walk_path = walk_path  self.markdown_text = ''  self.image_lst = []  self.posterior_image_lst = []  self.image_2_url_dic = {}  def _get_markdown_text(self):  with open(self.file_path, mode='r', encoding='utf-8') as f:  markdown_text = f.read()  self.markdown_text = markdown_text  def _process_markdown_text(self):  image_lst = re.findall(r'(!\[\[.*]])', self.markdown_text)  posterior_image_lst = [item[3:-2] for item in image_lst]  self.image_lst = image_lst  self.posterior_image_lst = posterior_image_lst  def _get_target_image_path(self, target_path):  for root, floders, files in os.walk(self.walk_path):  for file in files:  if file == target_path:  return str(Path(root) / file)  def _get_the_url_of_image(self, image_path):  image_url = self.upload.upload_image(image_path)  return image_url  def get_the_urls(self):  self._get_markdown_text()  self._process_markdown_text()  not_exist_image_index = []  for ix, (origin_image, target_path) in track(enumerate(zip(self.image_lst, self.posterior_image_lst))):  image_path = self._get_target_image_path(target_path)  if image_path is not None:  image_url = self._get_the_url_of_image(image_path)  self.image_2_url_dic[origin_image] = image_url  else:  not_exist_image_index.append(ix)  # 清楚掉需要?jiǎng)h除的index  num = 0  for ix in not_exist_image_index:  del self.image_lst[ix-num]  del self.posterior_image_lst[ix-num]  num += 1  def _the_transform_data_from(self, image_url):  data_form = f"""\n<div align=center><img src="{image_url}"></div>\n"""  return data_form  def _save_markdown_text(self, output_file='markdown_processed.txt'):  with open(output_file, mode='w', encoding='utf-8') as f:  f.write(self.markdown_text)  def get_transform(self):  self.get_the_urls()  # Judge the length  assert len(self.image_lst) == len(self.image_2_url_dic), f"上傳成功{len(self.image_2_url_dic)}張圖片,總共有{len(self.image_lst)}張圖片"  for origin_image, image_url in self.image_2_url_dic.items():  self.markdown_text = self.markdown_text.replace(origin_image, self._the_transform_data_from(image_url))  self._save_markdown_text()if __name__ == '__main__':  cookie = ''  # 輸入你的cookiefile_path = ''  # 輸入你要轉(zhuǎn)換的markdown文件地址upload = UploadPic(cookie)  transform = CSDNTransform(upload, file_path)  markdown_text = transform.get_transform()# 修改后的 Markdown 在當(dāng)前目錄的 markdown_processed.txt 文件中

一、上傳資源

首先我們解析 CSDN 上傳請求,這里隨便上傳一張圖片,觀察請求;

請求由三部分組成,分別是:1. 獲取存儲(chǔ)位置和簽名驗(yàn)證信息;2. 利用簽名等驗(yàn)證信息上傳文件;3. 獲取文件信息并顯示;

仔細(xì)觀察兩個(gè)請求,upload 請求是 GET ,csdn 請求是 POST,其結(jié)果很明顯 csdn 請求是主體,仔細(xì)觀察 csdn 的參數(shù),可以所有參數(shù)都可以利用 upload 的返回結(jié)果得到;

那么接下來我們開始構(gòu)造 upload 請求

import requestsheaders = {'accept': '*/*','accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6','content-type': 'application/json','cookie': '', # 輸入自己的cookies'origin': 'https://editor.csdn.net','priority': 'u=1, i','referer': 'https://editor.csdn.net/','sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"','sec-ch-ua-mobile': '?0','sec-ch-ua-platform': '"Windows"','sec-fetch-dest': 'empty','sec-fetch-mode': 'cors','sec-fetch-site': 'same-site','user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',
}params = {'type': 'blog','rtype': 'markdown','x-image-template': '','x-image-app': 'direct_blog','x-image-dir': 'direct','x-image-suffix': 'png',
}url = 'https://imgservice.csdn.net/direct/v1.0/image/upload'
response = requests.get(url, params=params, headers=headers)# 獲得數(shù)據(jù)
upload_data = response.json()

得到 json 內(nèi)容如下,通過比較該內(nèi)容下 expire 和 time 庫下的 time.time() * 1000,再根據(jù)英文名可以推斷,expire 表示的是上傳文件這一請求的失效時(shí)間,即 csdn 請求的最晚成功時(shí)間;

{'code': 200,'data': {'accessId': 'LTAI5tK31AXMAqwzaX1wn4hH','callbackUrl': 'eyJjYWxsYmFja0JvZHlUeXBlIjoiYXBwbGljYXRpb24vanNvbiIsImNhbGxiYWNrVXJsIjoiaHR0cHM6Ly9pbWdzZXJ2aWNlLmNzZG4ubmV0L2RpcmVjdC92MS4wL2ltYWdlL2NhbGxiYWNrIiwiY2FsbGJhY2tCb2R5Ijoie1wiZmlsZVBhdGhcIjpcImRpcmVjdC9jN2VlYWNjZjU2ZDM0MzM3OWQ2Yjk4ZmYwNGYyZWFjNS5wbmdcIixcImlzQXVkaXRcIjoxLFwieC1pbWFnZS1hcHBcIjpcImRpcmVjdF9ibG9nXCIsXCJ0eXBlXCI6XCJibG9nXCIsXCJ1cmxNZDVcIjpcImM3ZWVhY2NmNTZkMzQzMzc5ZDZiOThmZjA0ZjJlYWM1XCIsXCJydHlwZVwiOlwibWFya2Rvd25cIixcImhvc3RuYW1lXCI6XCJodHRwczovL2ltZy1ibG9nLmNzZG5pbWcuY24vXCIsXCJzaXplXCI6XCIke3NpemV9XCIsXCJ4LWltYWdlLWRpclwiOlwiZGlyZWN0XCIsXCJ3aWR0aFwiOlwiJHtpbWFnZUluZm8ud2lkdGh9XCIsXCJ4LWltYWdlLXN1ZmZpeFwiOlwicG5nXCIsXCJ1c2VybmFtZVwiOlwibTBfNzI5NDczOTBcIixcImhlaWdodFwiOlwiJHtpbWFnZUluZm8uaGVpZ2h0fVwifSJ9','dir': 'direct','expire': '1718611892700','filePath': 'direct/c7eeaccf56d343379d6b98ff04f2eac5.png','host': 'https://csdn-img-blog.oss-cn-beijing.aliyuncs.com','policy': 'eyJleHBpcmF0aW9uIjoiMjAyNC0wNi0xN1QwODoxMTozMi43MDBaIiwiY29uZGl0aW9ucyI6W1siY29udGVudC1sZW5ndGgtcmFuZ2UiLDAsMTA0ODU3NjAwXSxbInN0YXJ0cy13aXRoIiwiJGtleSIsImRpcmVjdC9jN2VlYWNjZjU2ZDM0MzM3OWQ2Yjk4ZmYwNGYyZWFjNS5wbmciXV19','signature': '2hRKp5YO3epBJe5+Qt7Ngi7P/y4='},'message': None,'msg': 'success'}

下面利用 upload 得到的請求來構(gòu)造 csdn 請求;

import requests
from requests_toolbelt.multipart.encoder import MultipartEncoderdef get_file(file_path):"""獲取文件的二進(jìn)制數(shù)據(jù)"""with open(file_path, mode='rb') as f:binary_data = f.read()return binary_dataheaders = {'Accept': 'application/json, text/javascript, */*; q=0.01','Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6','Connection': 'keep-alive','Origin': 'https://editor.csdn.net','Referer': 'https://editor.csdn.net/','Sec-Fetch-Dest': 'empty','Sec-Fetch-Mode': 'cors','Sec-Fetch-Site': 'cross-site','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0','sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"','sec-ch-ua-mobile': '?0','sec-ch-ua-platform': '"Windows"',
}success_action_status = '200'# upload 請求中獲取到的數(shù)據(jù)
key = upload_data['data']['filePath']
policy = upload_data['data']['policy']
OSSAccessKeyId = upload_data['data']['accessId']
signature = upload_data['data']['signature']
callback = upload_data['data']['callbackUrl']# 上傳的圖片位置,
file = get_file('') # 輸入需要上傳文件的位置files = {'key': (None, key),'policy': (None, policy),'OSSAccessKeyId': (None, OSSAccessKeyId),'success_action_status': (None, '200'),'signature': (None, signature),'callback': (None, callback),'file': ('image.png', file, 'image/png'),
}url = 'https://csdn-img-blog.oss-cn-beijing.aliyuncs.com/'
response = requests.post(url, headers=headers, files=files)print(response.text)

得到 Json 數(shù)據(jù)如下

{'code': 200,'data': {'hostname': 'https://img-blog.csdnimg.cn/','imageUrl': 'https://img-blog.csdnimg.cn/direct/97c5610606c140afb474800403140ea3.png','width': '1138','targetObjectKey': 'direct/97c5610606c140afb474800403140ea3.png','x-image-suffix': 'png','height': '239'},'msg': 'success'}

在其中 imageUrl 就表示上傳的圖片地址,同時(shí),圖片格式有許多種,面對不同的圖片格式,在嘗試觀察后發(fā)現(xiàn)只需要修改 upload 請求中 parms 中的 x-image-suffixcsdn 請求中 files 中的 file

整合得到完整上傳類如下:

import requests  class UploadPic:  def __init__(self, cookie):  self.cookie = cookie  # 解析  self.file_path = ''  self.img_type = ''  # 兩個(gè)請求體  self.upload_data = {}  self.csdn_data = {}  self.output_url = ''  def _get_file(self, file_path):  with open(file_path, mode='rb') as f:  binary_data = f.read()  return binary_data  def _upload_request(self):  headers = {  'accept': '*/*',  'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'content-type': 'application/json',  'cookie': self.cookie,  'origin': 'https://editor.csdn.net',  'priority': 'u=1, i',  'referer': 'https://editor.csdn.net/',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  'sec-fetch-dest': 'empty',  'sec-fetch-mode': 'cors',  'sec-fetch-site': 'same-site',  'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  }  params = {  'type': 'blog',  'rtype': 'markdown',  'x-image-template': '',  'x-image-app': 'direct_blog',  'x-image-dir': 'direct',  'x-image-suffix': self.img_type,  }  url = 'https://imgservice.csdn.net/direct/v1.0/image/upload'  response = requests.get(url, params=params, headers=headers)  try:  self.upload_data = response.json()  except Exception as e:  return e  def _csdn_request(self):  headers = {  'Accept': 'application/json, text/javascript, */*; q=0.01',  'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'Connection': 'keep-alive',  'Origin': 'https://editor.csdn.net',  'Referer': 'https://editor.csdn.net/',  'Sec-Fetch-Dest': 'empty',  'Sec-Fetch-Mode': 'cors',  'Sec-Fetch-Site': 'cross-site',  'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  }  files = {  'key': (None, self.upload_data['data']['filePath']),  'policy': (None, self.upload_data['data']['policy']),  'OSSAccessKeyId': (None, self.upload_data['data']['accessId']),  'success_action_status': (None, '200'),  'signature': (None, self.upload_data['data']['signature']),  'callback': (None, self.upload_data['data']['callbackUrl']),  'file': (f'image.{self.img_type}', self._get_file(self.file_path), f'image/{self.img_type}'),  }  url = 'https://csdn-img-blog.oss-cn-beijing.aliyuncs.com/'  response = requests.post(url, headers=headers, files=files)  try:  self.csdn_data = response.json()  self.output_url = self.csdn_data['data']['imageUrl']  except Exception as e:  return e  def upload_image(self, file_path):  self.file_path = file_path  self.img_type = self.file_path.split('.')[-1]  exception_1 = self._upload_request()  assert exception_1 is None, exception_1  exception_2 = self._csdn_request()  assert exception_2 is None, exception_2  return self.output_url  if __name__ == '__main__':  cookie = '' # 輸入你的cookie  upload = UploadPic(cookie)  output_url = upload.upload_image('')  #輸入你需要上傳的文件位置print(output_url)

二、替換 MD 中的引用文件為在線鏈接

首先,肯定是整體替換而不是單個(gè)替換,因此我們的流程為:1. 上傳所有文件,直到所有的文件都上傳成功;2. 替換所有文件;

首先提取出 Markdown 中所有的圖片信息,一般來說圖片信息都在兩個(gè)中括號(hào)之間 ![[ img_pic ]],使用 re 正則提取,代碼如下;

import refile_path = 'C:/Users/Administrator/Documents/Obsidian Vault/UE開發(fā)/My FirstGame Tutorial.md'with open(file_path, mode='r', encoding='utf-8') as f:markdown_text = f.read()image_lst = re.findall(r'(!\[\[.*\]\])', markdown_text)
posterior_image_lst = [item[3:-2] for item in image_lst]

提取出所有的 img_pic 后,我們需要在根目錄下尋找文件,一般來說在 Markdown 中文件名是不重復(fù)的;

import os
from pathlib import Pathdef get_target_image_path(target_path):walk_path = 'C:/Users/Administrator/Documents/Obsidian Vault/'for root, floders, files in os.walk(walk_path):for file in files:if file == target_path:return Path(root) / fileget_target_image_path(posterior_image_lst[0])

獲取到了絕對位置后,我們可以將圖片上傳,在檢查圖片全部都上傳完畢后,我們就可以替換 ![[ img_pic ]]

import os  
import re  
import requests  
from pathlib import Path  
from rich.progress import track  class UploadPic:  def __init__(self, cookie):  self.cookie = cookie  # 解析  self.file_path = ''  self.img_type = ''  # 兩個(gè)請求體  self.upload_data = {}  self.csdn_data = {}  self.output_url = ''  def _get_file(self, file_path):  with open(file_path, mode='rb') as f:  binary_data = f.read()  return binary_data  def _upload_request(self):  headers = {  'accept': '*/*',  'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'content-type': 'application/json',  'cookie': self.cookie,  'origin': 'https://editor.csdn.net',  'priority': 'u=1, i',  'referer': 'https://editor.csdn.net/',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  'sec-fetch-dest': 'empty',  'sec-fetch-mode': 'cors',  'sec-fetch-site': 'same-site',  'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  }  params = {  'type': 'blog',  'rtype': 'markdown',  'x-image-template': '',  'x-image-app': 'direct_blog',  'x-image-dir': 'direct',  'x-image-suffix': self.img_type,  }  url = 'https://imgservice.csdn.net/direct/v1.0/image/upload'  response = requests.get(url, params=params, headers=headers)  try:  self.upload_data = response.json()  except Exception as e:  return e  def _csdn_request(self):  headers = {  'Accept': 'application/json, text/javascript, */*; q=0.01',  'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',  'Connection': 'keep-alive',  'Origin': 'https://editor.csdn.net',  'Referer': 'https://editor.csdn.net/',  'Sec-Fetch-Dest': 'empty',  'Sec-Fetch-Mode': 'cors',  'Sec-Fetch-Site': 'cross-site',  'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Edg/126.0.0.0',  'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Microsoft Edge";v="126"',  'sec-ch-ua-mobile': '?0',  'sec-ch-ua-platform': '"Windows"',  }  files = {  'key': (None, self.upload_data['data']['filePath']),  'policy': (None, self.upload_data['data']['policy']),  'OSSAccessKeyId': (None, self.upload_data['data']['accessId']),  'success_action_status': (None, '200'),  'signature': (None, self.upload_data['data']['signature']),  'callback': (None, self.upload_data['data']['callbackUrl']),  'file': (f'image.{self.img_type}', self._get_file(self.file_path), f'image/{self.img_type}'),  }  url = 'https://csdn-img-blog.oss-cn-beijing.aliyuncs.com/'  response = requests.post(url, headers=headers, files=files)  try:  self.csdn_data = response.json()  self.output_url = self.csdn_data['data']['imageUrl']  except Exception as e:  return e  def upload_image(self, file_path):  self.file_path = file_path  self.img_type = self.file_path.split('.')[-1]  exception_1 = self._upload_request()  assert exception_1 is None, exception_1  exception_2 = self._csdn_request()  assert exception_2 is None, exception_2  return self.output_url  class CSDNTransform:  def __init__(self, upload:UploadPic, file_path, walk_path='C:/Users/Administrator/Documents/Obsidian Vault/'):  self.upload = upload  self.file_path = file_path  self.walk_path = walk_path  self.markdown_text = ''  self.image_lst = []  self.posterior_image_lst = []  self.image_2_url_dic = {}  def _get_markdown_text(self):  with open(self.file_path, mode='r', encoding='utf-8') as f:  markdown_text = f.read()  self.markdown_text = markdown_text  def _process_markdown_text(self):  image_lst = re.findall(r'(!\[\[.*]])', self.markdown_text)  posterior_image_lst = [item[3:-2] for item in image_lst]  self.image_lst = image_lst  self.posterior_image_lst = posterior_image_lst  def _get_target_image_path(self, target_path):  for root, floders, files in os.walk(self.walk_path):  for file in files:  if file == target_path:  return str(Path(root) / file)  def _get_the_url_of_image(self, image_path):  image_url = self.upload.upload_image(image_path)  return image_url  def get_the_urls(self):  self._get_markdown_text()  self._process_markdown_text()  not_exist_image_index = []  for ix, (origin_image, target_path) in track(enumerate(zip(self.image_lst, self.posterior_image_lst))):  image_path = self._get_target_image_path(target_path)  if image_path is not None:  image_url = self._get_the_url_of_image(image_path)  self.image_2_url_dic[origin_image] = image_url  else:  not_exist_image_index.append(ix)  # 清楚掉需要?jiǎng)h除的index  num = 0  for ix in not_exist_image_index:  del self.image_lst[ix-num]  del self.posterior_image_lst[ix-num]  num += 1  def _the_transform_data_from(self, image_url):  data_form = f"""\n<div align=center><img src="{image_url}"></div>\n"""  return data_form  def _save_markdown_text(self, output_file='markdown_processed.txt'):  with open(output_file, mode='w', encoding='utf-8') as f:  f.write(self.markdown_text)  def get_transform(self):  self.get_the_urls()  # Judge the length  assert len(self.image_lst) == len(self.image_2_url_dic), f"上傳成功{len(self.image_2_url_dic)}張圖片,總共有{len(self.image_lst)}張圖片"  for origin_image, image_url in self.image_2_url_dic.items():  self.markdown_text = self.markdown_text.replace(origin_image, self._the_transform_data_from(image_url))  self._save_markdown_text()if __name__ == '__main__':  cookie = ''  # 輸入你的cookiefile_path = ''  # 輸入你要轉(zhuǎn)換的markdown文件地址upload = UploadPic(cookie)  transform = CSDNTransform(upload, file_path)  markdown_text = transform.get_transform()# 修改后的 Markdown 在當(dāng)前目錄的 markdown_processed.txt 文件中

參考

requests庫post請求參數(shù)data、json和files的使用_requests post data-CSDN博客
HTTP協(xié)議之multipart/form-data請求分析_http form-data請求-CSDN博客

http://m.risenshineclean.com/news/58368.html

相關(guān)文章:

  • 公司剛成立網(wǎng)站怎么做如何推廣我的網(wǎng)站
  • 制作微網(wǎng)站公司軟文新聞發(fā)布網(wǎng)站
  • ih5平臺(tái)發(fā)展前景關(guān)鍵詞優(yōu)化
  • 一級(jí)a做爰片免費(fèi)無碼網(wǎng)站seo關(guān)鍵詞優(yōu)化的技巧
  • 廣東省做農(nóng)業(yè)網(wǎng)站銷售的公司上海seo招聘
  • 做公司網(wǎng)站比較好的寧波網(wǎng)站推廣平臺(tái)效果好
  • 網(wǎng)站引導(dǎo)頁怎么做的做個(gè)公司網(wǎng)站多少錢
  • 一級(jí)a做爰片完整網(wǎng)站網(wǎng)站搭建需要多少錢?
  • 山西運(yùn)城網(wǎng)站開發(fā)seo就業(yè)前景如何
  • 互聯(lián)網(wǎng)公司網(wǎng)站建設(shè)ppt模板下載站長素材免費(fèi)下載
  • 網(wǎng)站架構(gòu)設(shè)計(jì)師蘋果cms永久免費(fèi)建站程序
  • wordpress添加logo武漢seo霸屏
  • 如何自己做個(gè)簡單網(wǎng)站神馬搜索推廣
  • 酒店 網(wǎng)站建設(shè) 中企動(dòng)力如何引流推廣
  • 什么網(wǎng)站做海報(bào)賺錢武漢大學(xué)人民醫(yī)院
  • 2345應(yīng)用商店深圳網(wǎng)站設(shè)計(jì)十年樂云seo
  • 重慶優(yōu)化網(wǎng)站推廣seo點(diǎn)擊
  • 湘潭網(wǎng)站優(yōu)化公司服務(wù)營銷案例
  • 牡丹江站建站seo推廣
  • 網(wǎng)站的圖書資源建設(shè)網(wǎng)絡(luò)工程師是干什么的
  • 泰安網(wǎng)絡(luò)教育肇慶seo優(yōu)化
  • html5 中文網(wǎng)站模板廣告設(shè)計(jì)網(wǎng)站
  • io游戲網(wǎng)站濟(jì)南特大最新消息
  • 用vs怎么做網(wǎng)站的導(dǎo)航百度廣告位價(jià)格表
  • 怎么制作自己的免費(fèi)網(wǎng)站濟(jì)南做網(wǎng)站建設(shè)的公司
  • 網(wǎng)站構(gòu)建的友情鏈接怎么做營銷的方法和技巧
  • wordpress緩存無法清除seo網(wǎng)址
  • web 網(wǎng)站做甘特圖視頻app推廣
  • 合肥企業(yè)網(wǎng)站建設(shè)靠譜山東大學(xué)經(jīng)濟(jì)研究院
  • 怎么做優(yōu)惠卷網(wǎng)站廣東seo教程