lark 发送图片消息

2023-10-19 10:52
文章标签 图片 消息 发送 lark

本文主要是介绍lark 发送图片消息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 需求

2. 实现

2.1 获取数据源

# -*- coding: utf-8 -*-
import os
import json
import requests
import pandas as pd
from pathlib import PurePath, Path
import plotly.express as px
from requests_toolbelt import MultipartEncoderdef get_data():dt = ['2023-10-01', '2023-10-02', '2023-10-03', '2023-10-04', '2023-10-05', '2023-10-06', '2023-10-07', '2023-10-08']y1 = [0.701923, 0.653595, 0.683258, 0.647059, 0.670659, 0.637615, 0.736586, 0.685000]y2 = [i+0.1 for i in y1]data = {'dt': dt,'y1': y1,'y2': y2}df = pd.DataFrame(data)return df

或从hive中读数据

conn = BaseHook.get_connection('hive_cli_default')
conn_hive = connect(host=conn.host, port=conn.port, timeout=3600, auth_mechanism='PLAIN',user=conn.login, password=conn.password)
cursor = conn_hive.cursor()
cursor.execute('SET mapreduce.job.queuename=root.bigdata')
cursor.execute('set mapred.job.name={table}'.format(table=dag_name))
cursor.execute('set hive.vectorized.execution.enabled = false')
sql = '''select dt, y1, y2from table;
'''
cursor.execute(sql)
data = cursor.fetchall()
cursor.close()
df = pd.DataFrame(data, columns=['dt'] + ['y1', 'y2'])
return df# 或
# df = pd.read_sql(sql, con)

2.2 绘制图片

# 绘制折线图
def draw_img(df):fig = px.line(df, x='dt', y='y1')fig.add_scatter(x=df['dt'], y=df['y1'], name='y1')fig.add_scatter(x=df['dt'], y=df['y2'], name='y2')fig.update_traces(textfont_size=8)fig.layout.yaxis.title = "uv_ratio"# fig.show()return fig

2.3 存储图片

def save_img(fig, img_name):try:root_dir = os.path.dirname(__file__)except Exception as e:print(e)root_dir = PurePath(Path.cwd())root_dir = os.path.abspath(root_dir)print(root_dir)# 在该项目目录下创建images文件夹if not os.path.exists("images"):os.mkdir("images")img_path = f"{root_dir}/images/{img_name}"fig.write_image(img_path)return img_path

2.4 上传图片并获得图片ID

def upload_image(img_path):# 1. 获得tokenurl_1 = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal/"req_body = {"app_id": "cli_a23XXXX","app_secret": "4w8XXX"}data = bytes(json.dumps(req_body), encoding='utf8')result = requests.request("POST", url_1, headers={'Content-Type': 'application/json; charset=utf-8'}, data=data)# print(result.content)token = result.json()["tenant_access_token"]print(token)# 2. 上传图片url = "https://open.feishu.cn/open-apis/im/v1/images"multi_form = MultipartEncoder({'image_type': 'message', 'image': (open(f'{img_path}', 'rb'))})headers = {'Authorization': f'Bearer {token}',  # tenant_access_token'Content-Type': multi_form.content_type}response = requests.request("POST", url, headers=headers, data=multi_form)# print(response.headers['X-Tt-Logid'])  # for debug or oncall# print(response.content)  # Print Responseimg_id = eval(response.content.decode("utf-8"))["data"]["image_key"]return img_id

2.5 发送飞书图片消息

def send_markdown(title, token, dt, img_id_1, img_id_2):http_headers = {'content-type': 'application/json'}request_url = f'https://open.feishu.cn/open-apis/bot/v2/hook/{token}'request_data = {"msg_type": "interactive","card": {"config": {"wide_screen_mode": True,"enable_forward": True},"header": {"title": {"tag": "plain_text","content": f"{title}"},"template": "blue"},"elements": [{"tag": "div","fields": [{"is_short": True,"text": {"tag": "lark_md","content": f"**日期:**  {dt}"}},]},{"tag": "img","img_key": f"{img_id_1}","alt": {"tag": "plain_text","content": "图片"}},{"tag": "img","img_key": f"{img_id_2}","alt": {"tag": "plain_text","content": "图片"}},]}}response = requests.post(request_url, json=request_data, headers=http_headers)print(response)if response.status_code != 200:print('飞书消息发送失败,http_code={},http_message={}'.format(response.status_code, response.reason))else:print('飞书消息发送成功')

2.6 调用

dt = '2023-10-18'
df = get_data()
fig = draw_img(df)
fig.show()
img_path = save_img(fig, img_name='pv_ratio.png')
img_id = upload_image(img_path)
token = 'f8727e49-bd8e-40f1-8346-00d423d18268'   # 测试群
send_markdown('XX服务日报-近14日指标趋势图', token, dt, img_id_1, img_id_2)

这篇关于lark 发送图片消息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/239305

相关文章

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

Prompt - 将图片的表格转换成Markdown

Prompt - 将图片的表格转换成Markdown 0. 引言1. 提示词2. 原始版本 0. 引言 最近尝试将图片中的表格转换成Markdown格式,需要不断条件和优化提示词。记录一下调整好的提示词,以后在继续优化迭代。 1. 提示词 英文版本: You are an AI assistant tasked with extracting the content of

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

研究人员在RSA大会上演示利用恶意JPEG图片入侵企业内网

安全研究人员Marcus Murray在正在旧金山举行的RSA大会上公布了一种利用恶意JPEG图片入侵企业网络内部Windows服务器的新方法。  攻击流程及漏洞分析 最近,安全专家兼渗透测试员Marcus Murray发现了一种利用恶意JPEG图片来攻击Windows服务器的新方法,利用该方法还可以在目标网络中进行特权提升。几天前,在旧金山举行的RSA大会上,该Marcus现场展示了攻击流程,

恶意PNG:隐藏在图片中的“恶魔”

&lt;img src=&quot;https://i-blog.csdnimg.cn/blog_migrate/bffb187dc3546c6c5c6b8aa18b34b962.jpeg&quot; title=&quot;214201hhuuhubsuyuukbfy_meitu_1_meitu_2.jpg&quot;/&gt;&lt;/strong&gt;&lt;/span&gt;&lt;

Android中如何实现adb向应用发送特定指令并接收返回

1 ADB发送命令给应用 1.1 发送自定义广播给系统或应用 adb shell am broadcast 是 Android Debug Bridge (ADB) 中用于向 Android 系统发送广播的命令。通过这个命令,开发者可以发送自定义广播给系统或应用,触发应用中的广播接收器(BroadcastReceiver)。广播机制是 Android 的一种组件通信方式,应用可以监听广播来执行

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

(入门篇)JavaScript 网页设计案例浅析-简单的交互式图片轮播

网页设计已经成为了每个前端开发者的必备技能,而 JavaScript 作为前端三大基础之一,更是为网页赋予了互动性和动态效果。本篇文章将通过一个简单的 JavaScript 案例,带你了解网页设计中的一些常见技巧和技术原理。今天就说一说一个常见的图片轮播效果。相信大家在各类电商网站、个人博客或者展示页面中,都看到过这种轮播图。它的核心功能是展示多张图片,并且用户可以通过点击按钮,左右切换图片。