requests.get()///post函数///base64函数

1.requests.get()

一般的用法:r=requests.get(url)
或者是用上session:
r=requests.session()
r=r.get(url)

get()收集的是什么内容呢?

-- r.status_code     #响应状态码
-- r.content           #字节方式的响应体(二进制形式),会自动为你解码 gzip 和 deflate 压缩
-- r.headers          #以字典对象存储服务器响应头(http响应头的信息),但是这个字典比较特殊,字典键不区分大小写,若键不存在则返回None
-- r.json()             #Requests中内置的JSON解码器
-- r.url                  # 获取url
-- r.encoding         # 编码格式(由headers推测编码方式)
-- r.cookies           # 获取cookie
-- r.raw                #返回原始响应体
-- r.text               #字符串方式的响应体,会自动根据响应头部的字符编码进行解码
-- r.raise_for_status() #失败请求(非200响应)抛出异常

当然还有很多,这里再说一下headers:

 2.post函数(requests模块)

一般用法:r=post(url,data=post)

括号里的post(只是字典名,可以换成别的)是一个构造的字典,如:post={'margin':flag}
作用对指定的url是上传指定的值

3.base64函数

base64加密:base64.b64encode()

base64解密:base64.b64decode()

base64也支持base32、base16加解密,只需要将函数中对应的数字修改就行了。

但是要注意,base64解码后的数据是byte类型,需要用decode()函数解码为字符串

是因为字符串有byte类型和str类型,有时操作数类型和操作类型不匹配就会报错……这时候就要把类型转换一下(无论是转换操作数还是操作都行,只要两者匹配

一个简单的方法:
  1、byte型转str型

          mid=mid.decode()

  2、str型转byte型

          mid=mid.encode()

转载于:https://www.cnblogs.com/RenoStudio/p/10355165.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
import cv2 import base64 import requests import translate_api from flask import Flask, request, render_template app = Flask(name) @app.route('/') def index(): return render_template('index.html') @app.route('/process', methods=['POST']) def process(): file = request.files['image'] file.save('uploaded_image.jpg') # 使用OpenCV或Pillow加载和处理图像数据 result = ''.join(ocr('uploaded_image.jpg')) #image = cv2.imread('uploaded_image.jpg') #result = image_recognition(image) translation = translate_api.translate(result) return render_template('result.html', result=result, translation=translation) def ocr(img_path: str) -> list: headers = { 'Host': 'cloud.baidu.com', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36 Edg/89.0.774.76', 'Accept': '/', 'Origin': 'https://cloud.baidu.com', 'Sec-Fetch-Site': 'same-origin', 'Sec-Fetch-Mode': 'cors', 'Sec-Fetch-Dest': 'empty', 'Referer': 'https://cloud.baidu.com/product/ocr/general', 'Accept-Language': 'zh-CH,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6', } # 打开图片并对其使用 base64 编码 with open(img_path, 'rb') as f: img = base64.b64encode(f.read()) data = { 'image': 'data:image/jpeg;base64,'+str(img)[2:-1], 'image_url': '', 'type': 'https://aip.baidubce.com/rest/2.0/ocr/v1/general_basic', 'detect_direction': 'false' } # 开始调用 ocr 的 api response = requests.post( 'https://cloud.baidu.com/aidemo', headers=headers, data=data) ocr_text = [] result = response.json()['data'] if not result.get('words_result'): return [] # 将识别的字符串添加到列表里面 for r in result['words_result']: text = r['words'].strip() ocr_text.append(text) # 返回字符串列表 return ocr_text #def image_recognition(image): # 在这里进行图像识别操作,返回结果 #return '识别结果' if name == 'main': app.run() 修改代码
07-23
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值