婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 用Python給二維碼圖片添加提示文字

用Python給二維碼圖片添加提示文字

熱門標簽:外呼系統(tǒng)哪些好辦 如何申請400電話費用 沈陽外呼系統(tǒng)呼叫系統(tǒng) 池州外呼調(diào)研線路 沈陽人工外呼系統(tǒng)價格 沈陽防封電銷卡品牌 江西省地圖標注 武漢外呼系統(tǒng)平臺 富錦商家地圖標注

一、需求:

判斷當前瀏覽器是否為微信,是的話挑起微信支付,不是的話,顯示二維碼圖片并提示用戶到微信中打開

二、效果圖:

三、代碼實現(xiàn):

1. 判斷是否微信

# toolbox.py
from typing import Any
 
 
class UserAgent:
    def __init__(self, user_agent: str = '', request: Any = None):
        if request is not None:
            try:
                user_agent = request.headers.get('user-agent', '')  # For Sanic
            except AttributeError:
                user_agent = request.META.get('HTTP_USER_AGENT', '')  # Django
        self.user_agent = user_agent
 
    @property
    def is_alipay(self) -> bool:
        return "AlipayClient/" in self.user_agent
 
    @property
    def is_wechat(self) -> bool:
        return "MicroMessenger/" in self.user_agent
 
    @property
    def is_qq(self) -> bool:
        return " QQ/" in self.user_agent
 
    @property
    def scan_type(self) -> str:
        if self.is_wechat or self.is_qq:
            return "wechat"
        if self.is_alipay:
            return "alipay"
        return "unknown"

2. 給圖片加文字 (參考了這篇文章并做了一些修改:https://www.jb51.net/article/175078.htm)

# image_text.py
"""
給圖片(如二維碼)添上文字
Usage::
    >>> from xxx import deco_image
    >>> deco_image(image_path, text)  # 替換舊圖片
    >>> deco_image(image_path, text, new_path, color='red')  # 保留舊圖片并指定文字顏色
"""
from pathlib import Path
from typing import Optional, Tuple, Union
 
from PIL import Image, ImageDraw, ImageFont  # pip install pillow
 
TIP = "請用微信掃碼支付\n或分享到微信中打開"
 
 
# 獲取圖片寬度
def get_img_width(fname) -> int:
    return Image.open(fname).size[0]
 
 
# 獲取圖片高度
def get_img_height(fname) -> int:
    return Image.open(fname).size[1]
 
 
# 給圖片加文字
# 生成blank_img空白圖片,加上文字之后生成新圖片或覆蓋舊圖, 寬度為origin_img原始圖片的寬度
 
MARGIN_LEFT, MARGIN_TOP = 50, 15
FONT_SIZE = 22
FONT_COLOR = "red"
 
 
def gen_text_img(
    origin_img: Union[Path, str],
    text: str,
    img_path=None,
    color=FONT_COLOR,
    font_size: int = FONT_SIZE,
    margin_left: int = MARGIN_LEFT,
    margin_top: int = MARGIN_TOP,
    blank_img=None,
    font_path: Optional[str] = None,
    show_img: bool = False,
) -> Union[Path, str]:
    width = get_img_width(origin_img)
    if blank_img is None:
        blank_img = Path(f"/tmp/blank-{width}.png")
    elif isinstance(blank_img, str):
        blank_img = Path(blank_img)
    if not blank_img.exists():
        Image.new("RGB", (width, 70), (255, 255, 255)).save(blank_img)
    im = Image.open(blank_img)
    draw = ImageDraw.Draw(im)
    if font_path is None:
        # font_path = r"C:\Windows\Fonts\simsun.ttc"
        # font_path = "/System/Library/Fonts/Supplemental/Songti.ttc"
        font_path = "/usr/share/fonts/truetype/windows-font/Songti.ttc"
    fnt = ImageFont.truetype(font_path, font_size)
    draw.text((margin_left, margin_top), text, fill=color, font=fnt)
    if img_path is None:
        img_path = Path(origin_img)
        img_path = img_path.with_name(f"{img_path.stem}-{len(text)}{img_path.suffix}")
    im.save(img_path)
    if show_img:
        im.show()
    return img_path
 
 
# 拼接圖片,把上面生成的文字圖片拼接到原圖上面
# 生成一張寬度一致,高度為兩張圖片之和的空白長圖
# 分別打開圖片進行粘貼到空白長圖里面
 
def join_imgs(text_img, origin_img, new_path=None) -> None:
    w = get_img_width(text_img)
    fh = get_img_height(text_img)
    oh = get_img_height(origin_img)
 
    blank_long_img = Image.new("RGBA", (w, fh + oh))  # 空白長圖
 
    font_img = Image.open(text_img).resize((w, fh), Image.ANTIALIAS)
    blank_long_img.paste(font_img, (0, 0))
 
    img1 = Image.open(origin_img).resize((w, oh), Image.ANTIALIAS)
    blank_long_img.paste(img1, (0, fh))
    if new_path is None:
        new_path = origin_img
    blank_long_img.save(new_path)
    blank_long_img.show()
 
 
def deco_image(
    fpath: Union[Path, str],  # 圖片路徑
    text: str = TIP,  # 要添加的文字
    new_path: Union[Path, str, None] = None,  # 新圖片要保存的路徑(默認覆蓋原圖)
    color: Union[str, Tuple[int, int, int]] = FONT_COLOR,  # 文字顏色
    font_size: int = FONT_SIZE,  # 文字高度
    margin_left: int = MARGIN_LEFT,
    margin_top: int = MARGIN_TOP,
) -> None:
    text_img = gen_text_img(
        fpath,
        text,
        color=color,
        font_size=font_size,
        margin_left=margin_left,
        margin_top=margin_top,
    )
    join_imgs(text_img, fpath)

3. 如果系統(tǒng)缺字體,那么需要去下載

sudo mkdir /usr/share/fonts/truetype/windows-font
sudo chmod 777 /usr/share/fonts/truetype/windows-font
cd /usr/share/fonts/truetype/windows-font
wget https://gitee.com/waketzheng/carstino/attach_files/703450/download/Songti.ttc  # 該文件比較大,有66.9MB

4. 調(diào)起支付或生成圖片

from pathlib import Path
from hashlib import md5
 
import qrcode  # pip install qrcode
from sanic import Blueprint
from sanic.log import logger
from sanic.request import Request
from sanic.response import json
 
from .models import Order
from .image_text import deco_image
from .toolbox import UserAgent
from .utils import async_http_post, get_host
from .consts import URL_PREFIX, WX_PAY_URL
 
 
bp = Blueprint("epay", url_prefix=URL_PREFIX)
 
async def get_qf_mch(community):
    pass
 
 
@bp.route("/pay-link", methods=["POST"])
async def pay_link(request: Request):
    requires, data = ["bills", "total", "next"], request.json
    logger.info(f"{request.url = } ;  {request.json = }")
    # 已經(jīng)1分鐘內(nèi)生成過對應訂單的,直接去支付
    content = request.body + f"{datetime.now():%y%m%d%H%M%S}".encode()
    body = md5(content).hexdigest()
    if not (order := await Order.filter(body=body).first()):
        order = await new_pay_order(origin, data, request, body)
    mchid, mch_name = await get_qf_mch(order.community)
    if mchid:
        host = get_host(request.headers)
        if not UserAgent(request=request).is_wechat:
            # 故判斷當前是否在微信里,如果不是就直接生成二維碼
            frontend_url = data["next"]
            fpath = "payit/" + md5(frontend_url.encode()).hexdigest() + ".png"
            if not (p := BASE_DIR / "media" / fpath).parent.exists():
                p.parent.mkdir(parents=True)
            qrcode.make(frontend_url).save(p)
            deco_image(p)
            img_url = host + URL_PREFIX + "/media/" + fpath
            return json({"payUrl": img_url})
        return json(qf_pay_it(mchid, mch_name, order, host=host))
    url = WX_PAY_URL
    if not (request_data := order.post_data).get("mch"):
        request_data.update(mch=1)  # 未配置支付的,先用1
    res = await async_http_post(url, request_data)
    try:
        res_json = res.json()
    except Exception as e:
        logger.error(f"{e = }; {url = }; {order.post_data=}; {res.content = }")
    return json(res_json)


到此這篇關于用Python給二維碼圖片添加提示文字的文章就介紹到這了,更多相關Python給二維碼添加文字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python 使用MyQR和qrcode來制作二維碼
  • python-圖片流傳輸?shù)乃悸芳笆纠?url轉換二維碼)
  • 基于Python生成個性二維碼過程詳解
  • Python使用qrcode二維碼庫生成二維碼方法詳解
  • Python qrcode 生成一個二維碼的實例詳解
  • 通過python掃描二維碼/條形碼并打印數(shù)據(jù)
  • Python django框架輸入漢字,數(shù)字,字符生成二維碼實現(xiàn)詳解
  • 一行Python代碼制作動態(tài)二維碼的實現(xiàn)
  • 使用python寫的opencv實時監(jiān)測和解析二維碼和條形碼
  • Python二維碼生成識別實例詳解
  • 用python生成(動態(tài)彩色)二維碼的方法(使用myqr庫實現(xiàn))
  • python二維碼操作:對QRCode和MyQR入門詳解
  • Python3批量生成帶logo的二維碼方法
  • Python使用MyQR制作專屬動態(tài)彩色二維碼功能

標簽:銅川 通遼 呂梁 株洲 常德 阿里 黑龍江 潛江

巨人網(wǎng)絡通訊聲明:本文標題《用Python給二維碼圖片添加提示文字》,本文關鍵詞  用,Python,給,二維,碼,圖片,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《用Python給二維碼圖片添加提示文字》相關的同類信息!
  • 本頁收集關于用Python給二維碼圖片添加提示文字的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久99这里只有精品| 91欧美激情一区二区三区成人| 久久99九九99精品| 色天天综合久久久久综合片| 欧美一级高清片| 亚洲理论在线观看| 国产成人午夜精品影院观看视频 | 美女任你摸久久| 99久久国产综合精品女不卡| 这里是久久伊人| 亚洲激情一二三区| 国产成人综合精品三级| 欧美一区二区观看视频| 一区二区高清视频在线观看| 国产不卡在线一区| 精品久久久久99| 午夜欧美电影在线观看| 91麻豆福利精品推荐| 国产亚洲短视频| 麻豆国产欧美日韩综合精品二区| 欧美无人高清视频在线观看| 亚洲丝袜另类动漫二区| 国产99精品在线观看| 精品福利在线导航| 美女免费视频一区二区| 欧美酷刑日本凌虐凌虐| 亚洲国产综合91精品麻豆| 色av成人天堂桃色av| 综合激情成人伊人| 99久久99久久精品免费观看| 国产视频911| 国产成人av电影在线播放| 精品国产不卡一区二区三区| 韩国精品免费视频| 国产午夜亚洲精品羞羞网站| 国产99久久久国产精品免费看| 国产色一区二区| 成人黄色在线视频| 中文字幕亚洲一区二区va在线| 99视频在线精品| 亚洲精品久久7777| 欧美精品在线视频| 久久成人免费日本黄色| 久久蜜桃av一区精品变态类天堂| 国产呦萝稀缺另类资源| 国产色婷婷亚洲99精品小说| 99这里都是精品| 亚洲第四色夜色| 91精品国产aⅴ一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 国产亚洲一二三区| a级精品国产片在线观看| 亚洲精品大片www| 欧美精品高清视频| 国产精品99久久久久久宅男| 亚洲人成网站精品片在线观看| 欧美午夜在线一二页| 蜜乳av一区二区| 国产精品三级在线观看| 欧美亚洲禁片免费| 毛片av一区二区| 日韩理论片在线| 欧美一级生活片| 成人性生交大片免费看在线播放| 亚洲午夜羞羞片| 久久婷婷国产综合精品青草| 色噜噜夜夜夜综合网| 美女精品一区二区| 亚洲三级在线免费| 日韩一卡二卡三卡四卡| 97精品视频在线观看自产线路二| 亚洲国产精品天堂| 国产午夜精品久久久久久免费视 | 国产日韩av一区| 欧美天堂一区二区三区| 久久国产尿小便嘘嘘尿| 综合久久久久久| 日韩欧美三级在线| 色婷婷综合五月| 国产一区亚洲一区| 午夜久久久久久久久| 欧美激情一区二区三区蜜桃视频 | 国产丝袜在线精品| 欧美日韩精品二区第二页| 国产精品18久久久久久久久| 亚洲成人tv网| 亚洲免费观看视频| 欧美激情一区在线观看| 日韩一级免费观看| 欧美私模裸体表演在线观看| 成人在线视频首页| 国产一区二区三区高清播放| 婷婷中文字幕综合| 亚洲乱码中文字幕| 国产精品欧美久久久久一区二区| 日韩欧美国产高清| 8x8x8国产精品| 精品视频在线看| 色狠狠综合天天综合综合| 国产一区二区在线免费观看| 日本不卡免费在线视频| 午夜精品国产更新| 亚洲免费资源在线播放| 国产精品国产三级国产aⅴ无密码| 2024国产精品| 亚洲精品一区二区三区影院 | 国内欧美视频一区二区| 视频一区二区中文字幕| 午夜国产不卡在线观看视频| 亚洲男人的天堂在线观看| 日韩理论片在线| 亚洲精品视频一区二区| 亚洲激情中文1区| 亚洲一区二区偷拍精品| 一区2区3区在线看| 亚洲一区二区在线播放相泽| 亚洲一卡二卡三卡四卡五卡| 亚洲电影一级片| 亚洲高清视频在线| 日韩高清在线电影| 美女一区二区在线观看| 韩国中文字幕2020精品| 国产91精品免费| 99免费精品在线| 欧美色图在线观看| 欧美一区二区三区视频免费| 日韩午夜激情av| 国产视频亚洲色图| 亚洲老司机在线| 午夜精品爽啪视频| 老司机精品视频线观看86| 国产真实乱子伦精品视频| 成人晚上爱看视频| 欧美伊人久久久久久久久影院| 欧美视频精品在线| 日韩欧美成人一区| 国产精品国产三级国产aⅴ入口| 1000精品久久久久久久久| 亚洲综合偷拍欧美一区色| 视频一区二区欧美| 国产精品资源网站| 色综合久久久久久久久久久| 欧美久久高跟鞋激| 国产性色一区二区| 亚洲综合激情网| 国产在线播精品第三| 日本黄色一区二区| 亚洲精品一区二区三区在线观看 | 综合色天天鬼久久鬼色| 亚洲一区二区在线免费观看视频| 另类的小说在线视频另类成人小视频在线| 国产精品白丝jk黑袜喷水| 欧美体内she精高潮| 国产免费久久精品| 偷拍日韩校园综合在线| 成人网在线免费视频| 777午夜精品免费视频| 国产目拍亚洲精品99久久精品| 亚洲成人动漫在线免费观看| 国产成人a级片| 3d成人动漫网站| 中文字幕一区二区三| 久久99国产精品成人| 欧美性做爰猛烈叫床潮| 国产日本亚洲高清| 日韩国产成人精品| 欧洲精品视频在线观看| 国产精品久久看| 久久国产日韩欧美精品| 欧美喷潮久久久xxxxx| 日韩一区中文字幕| 福利一区福利二区| 精品人伦一区二区色婷婷| 亚洲国产精品影院| 91免费精品国自产拍在线不卡| 久久久久综合网| 美女一区二区视频| 91精品国产欧美一区二区18| 亚洲一区二区三区四区在线| 成人av网址在线观看| 26uuu成人网一区二区三区| 亚洲成av人综合在线观看| av亚洲精华国产精华精华| 久久久欧美精品sm网站| 久久国产精品第一页| 6080亚洲精品一区二区| 亚洲国产毛片aaaaa无费看| 色琪琪一区二区三区亚洲区| 国产精品天干天干在线综合| 国产一区二区主播在线| 久久久久久久久久久久久夜| 精品一区二区三区影院在线午夜| 日韩限制级电影在线观看| 麻豆精品在线视频| 欧美一级二级在线观看| 麻豆精品在线播放| 久久综合九色综合欧美就去吻| 久久精品国产一区二区三| 26uuu久久天堂性欧美| 国产一区二区三区精品欧美日韩一区二区三区 |