当前位置: 首页 > article >正文

Grafana 表格自定义下载样式。

我这边的方案是通过 grafana嵌套在iframe中然后获取数据postmessage 给父页面 调用 excel.js 下载。增加一个html panel , 在 onlint 添加如下代码。该代码会在目标panel的标题上 增加一个 按钮点击后触发。var targetPanelId 8; setTimeout(function() { var panel $(.react-grid-item[data-panelid targetPanelId ]); var header panel.find([data-testidheader-container]); if (header.length 0) header panel.find(header); var btn $(button⬇ Download/button) .attr(contenteditable, false) .css({ padding: 2px 12px, font-size: 12px, background: #000, color: #fff, border: none, border-radius: 4px, cursor: pointer, user-select: none, pointer-events: auto, z-index: 99999 }); btn.on(click, function(e) { e.stopPropagation(); e.stopImmediatePropagation(); // ★ 从 React 内部直接取当前显示的完整数据 function extractData(el) { var fiberKey Object.keys(el).find(function(k) { return k.startsWith(__reactFiber$) || k.startsWith(__reactInternalInstance$); }); if (!fiberKey) return null; var fiber el[fiberKey]; var node fiber; var depth 100; while (node depth-- 0) { var p node.memoizedProps || {}; // Grafana 把查询结果放在 props.data.series if (p.data p.data.series p.data.series.length 0) { return p.data.series; } if (p.data Array.isArray(p.data.fields)) { return [p.data]; } if (p.frames p.frames.length 0) { return p.frames; } node node.return; } return null; } // 从 panel 容器开始找 var frames null; var dom panel[0]; // 先从 panel 根元素找 frames extractData(dom); // 没找到就遍历子元素 if (!frames) { var children dom.querySelectorAll(div); for (var i 0; i children.length !frames; i) { frames extractData(children[i]); } } if (!frames || frames.length 0) { console.error(❌ 未找到数据); return; } // 解析 DataFrame → headers rows var headers []; var rows []; frames.forEach(function(frame) { var fields frame.fields || []; if (fields.length 0) return; if (headers.length 0) { headers fields.map(function(f) { return f.config f.config.displayName ? f.config.displayName : f.name || ; }); } // values 可能是数组、ArrayVector、TypedArray var columns fields.map(function(f) { var v f.values; if (Array.isArray(v)) return v; if (v v.buffer) return Array.from(v.buffer); if (v v.toArray) return v.toArray(); if (v typeof v.length number) return Array.from(v); return []; }); var rowCount columns[0] ? columns[0].length : 0; for (var i 0; i rowCount; i) { var row []; for (var j 0; j columns.length; j) { var cell columns[j][i]; // 时间戳转可读 if (fields[j].type time typeof cell number) { cell new Date(cell 1e12 ? cell : cell * 1000) .toISOString().replace(T, ).slice(0, 19); } row.push(cell ! null ? cell : ); } rows.push(row); } }); console.log( 表头:, headers); console.log( 行数:, rows.length); console.log( 前3行:, rows.slice(0, 3)); // postMessage 给父页面 var message { type: GRAFANA_PANEL_DATA, panelId: targetPanelId, timestamp: new Date().toISOString(), data: { headers: headers, rows: rows, rowCount: rows.length } }; if (window.parent window.parent ! window) { window.parent.postMessage(message, *); } else { window.postMessage(message, *); } console.log(✅ 已发送 rows.length 行); }); btn.on(mousedown pointerdown dragstart, function(e) { e.stopPropagation(); e.stopImmediatePropagation(); }); header.css({ display: flex, align-items: center }); header.append(btn); }, 1000);

相关文章:

Grafana 表格自定义下载样式。

我这边的方案是通过 grafana嵌套在iframe中,然后获取数据postmessage 给父页面 调用 excel.js 下载。增加一个html panel , 在 onlint 添加如下代码。该代码会在目标panel的标题上 增加一个 按钮,点击后触发。var targetPanelId 8;setTimeout(function(…...

6GB显存也能玩转AI绘画:FLUX.1-dev FP8量化模型完全指南

6GB显存也能玩转AI绘画:FLUX.1-dev FP8量化模型完全指南 【免费下载链接】flux1-dev 项目地址: https://ai.gitcode.com/hf_mirrors/Comfy-Org/flux1-dev 还在为显卡配置不足而无法体验AI绘画的魅力而烦恼吗?FLUX.1-dev FP8量化模型正是为你量身…...

OpenScreen——Screen Studio平替开源屏幕录制神器

你是否也曾为制作一个简单的产品演示视频而焦头烂额?花大价钱买的录屏软件,结果导出的视频角落里永远有个去不掉的水印?今天给大家安利一款刚在 GitHub 爆火的开源神器,彻底解决你的录屏烦恼。一、那些年,我们踩过的录…...

DataSphere Studio:企业级数据开发平台的7大核心优势与完整使用指南

DataSphere Studio:企业级数据开发平台的7大核心优势与完整使用指南 【免费下载链接】DataSphereStudio WeBankFinTech/DataSphereStudio: 是腾讯金融科技的一个数据开发平台,具有强大的数据处理,分析,可视化和机器学习功能&#…...

百川2-13B-Chat效果展示:用Python模拟百川2推理过程(token-by-token生成可视化)

百川2-13B-Chat效果展示:用Python模拟百川2推理过程(token-by-token生成可视化) 1. 项目介绍 1.1 百川2-13B-Chat模型概述 百川2-13B-Chat是百川智能推出的130亿参数对话大模型,其4bit量化版本在保持性能的同时大幅降低了显存需…...

Qwen3-ASR-0.6B真实效果:直播间弹幕语音→实时字幕滚动+敏感词过滤联动

Qwen3-ASR-0.6B真实效果:直播间弹幕语音→实时字幕滚动敏感词过滤联动 1. 开篇:直播间语音转文字的痛点 做直播的朋友都知道,实时字幕是个让人又爱又恨的功能。爱的是它能提升观众体验,让不方便开声音的人也能看懂内容&#xff…...

电-热-气综合能源系统协同优化Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。👇 关注我领取海量matlab电子书和数学建模资料🍊个人信条:格物致知,完整Matl…...

QPDF技术解析:基于Qt WebEngine的PDF查看器架构设计与应用实践

QPDF技术解析:基于Qt WebEngine的PDF查看器架构设计与应用实践 【免费下载链接】qpdf PDF viewer widget for Qt 项目地址: https://gitcode.com/gh_mirrors/qpd/qpdf 在当今数字化文档处理领域,PDF格式已成为跨平台文档交换的事实标准。对于Qt开…...

PDFMathTranslate:如何实现学术PDF的完美翻译?3个关键技巧让阅读效率提升300%

PDFMathTranslate:如何实现学术PDF的完美翻译?3个关键技巧让阅读效率提升300% 【免费下载链接】PDFMathTranslate PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/Dee…...

AI 模型推理性能瓶颈排查与分析

AI 模型推理性能瓶颈排查与分析 随着AI技术的广泛应用,模型推理性能成为影响实际落地的关键因素。无论是实时推荐系统还是自动驾驶,延迟或吞吐量不达标都可能导致业务损失。性能瓶颈往往隐藏于模型结构、硬件资源或数据处理流程中,需要系统化…...

AI辅助开发实践:利用快马平台智能扩展用户行为分析分群功能

最近在做一个用户管理系统的功能扩展,需要增加智能用户分群功能。这个需求听起来简单,但实际操作中涉及到数据整合、算法选择、可视化展示等多个环节。好在发现了InsCode(快马)平台,它的AI辅助开发功能帮了大忙。 需求分析阶段 先用平台的AI对…...

专业级GTA5辅助工具:YimMenu全维度安全防护与功能增强指南

专业级GTA5辅助工具:YimMenu全维度安全防护与功能增强指南 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/…...

C++ 编译器优化参数解析

C编译器优化参数解析:提升性能的关键 在C开发中,编译器优化是提升程序性能的重要手段。通过调整编译器的优化参数,开发者可以在不修改代码的情况下显著提高程序的运行效率、减少内存占用或缩短启动时间。不同的优化选项适用于不同的场景&…...

3步掌握猫抓扩展:网页资源嗅探工具全面使用指南

3步掌握猫抓扩展:网页资源嗅探工具全面使用指南 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为在线视频无法保存而困扰吗&#…...

魔兽争霸III现代兼容性终极指南:用Warcraft Helper重获完美体验

魔兽争霸III现代兼容性终极指南:用Warcraft Helper重获完美体验 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸III在现代电…...

Windows 11硬件限制终极解决方案:MediaCreationTool.bat完整部署指南

Windows 11硬件限制终极解决方案:MediaCreationTool.bat完整部署指南 【免费下载链接】MediaCreationTool.bat Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2! 项目地址: https://gitcode.com/gh_mirrors/me/MediaCreationTool…...

C++ 模板参数推导机制剖析

C 模板参数推导机制剖析 C的模板参数推导是泛型编程的核心机制之一,它允许编译器在调用模板函数或类时自动推断类型参数,从而减少冗余代码并提升开发效率。理解这一机制不仅能帮助开发者编写更灵活的代码,还能避免因类型推导错误导致的编译问…...

【NOIP】1998真题解析 luogu-P1008 三连击 | GESP三、四级以上可练习

NOIP 1998 普及组真题,主要考察枚举算法与数位分离。题目要求将 这些数字进行组合,寻找符合特定比例的三位数。这是一个很经典的暴力枚举题。GESP三、四级以上可练习。题目难度⭐⭐☆☆☆,洛谷难度等级普及−。 luogu-P1008 [NOIP 1998 普…...

5个高效步骤打造Dell G15终极散热控制中心

5个高效步骤打造Dell G15终极散热控制中心 【免费下载链接】tcc-g15 Thermal Control Center for Dell G15 - open source alternative to AWCC 项目地址: https://gitcode.com/gh_mirrors/tc/tcc-g15 为什么专业游戏玩家和工程师都在抛弃官方散热软件?在高性…...

Go Context 生命周期与控制流分析

Go Context 生命周期与控制流分析 在Go语言中,Context是控制并发任务生命周期和传递请求范围数据的重要机制。它广泛应用于超时控制、取消信号传递以及跨API边界的数据共享。理解Context的生命周期及其对控制流的影响,对于编写高效、健壮的并发程序至关…...

LibreCAD完全指南:零基础掌握开源CAD绘图的实战秘籍

LibreCAD完全指南:零基础掌握开源CAD绘图的实战秘籍 【免费下载链接】LibreCAD LibreCAD is a cross-platform 2D CAD program written in C17. It can read DXF/DWG files and can write DXF/PDF/SVG files. It supports point/line/circle/ellipse/parabola/splin…...

如何在Windows 10上免费安装Android子系统:3步搞定完整指南

如何在Windows 10上免费安装Android子系统:3步搞定完整指南 【免费下载链接】WSA-Windows-10 This is a backport of Windows Subsystem for Android to Windows 10. 项目地址: https://gitcode.com/gh_mirrors/ws/WSA-Windows-10 想在你的Windows 10电脑上…...

微信聊天记录管理新范式:WeChatMsg让数据掌控回归用户

微信聊天记录管理新范式:WeChatMsg让数据掌控回归用户 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeCha…...

为什么Python开发者需要关注RadarSimPy:现代雷达系统仿真的技术突破

为什么Python开发者需要关注RadarSimPy:现代雷达系统仿真的技术突破 【免费下载链接】radarsimpy Radar Simulator built with Python and C 项目地址: https://gitcode.com/gh_mirrors/ra/radarsimpy 在自动驾驶、无人机探测和智能安防等领域,雷…...

3种方法让旧打印机秒变AirPrint:Docker容器化改造指南

3种方法让旧打印机秒变AirPrint:Docker容器化改造指南 【免费下载链接】cups-avahi-airprint Docker image for CUPS intended as an AirPrint relay 项目地址: https://gitcode.com/gh_mirrors/cu/cups-avahi-airprint 你是否曾遇到过这样的场景&#xff1a…...

OpenClaw(龙虾)WSL Ubuntu 环境安装配置完整指南

从零开始在 WSL Ubuntu 中安装 OpenClaw,配置公司中转站,解决各种问题,最终成功运行。目录环境准备OpenClaw 安装配置文件详解常见问题与解决方案日常使用指南完整配置模板一、环境准备1.1 确认 WSL Ubuntu 环境# 查看 Ubuntu 版本 lsb_relea…...

手机检测结果JSON格式解析:DAMO-YOLO WebUI后端返回字段说明

手机检测结果JSON格式解析:DAMO-YOLO WebUI后端返回字段说明 1. 引言 当你使用那个基于DAMO-YOLO的手机检测系统时,有没有好奇过:点击“检测手机”按钮后,后台到底发生了什么?系统是怎么把一张图片变成一个个红色框框…...

Windows苹果触控板驱动完全指南:5分钟实现原生级触控体验

Windows苹果触控板驱动完全指南:5分钟实现原生级触控体验 【免费下载链接】mac-precision-touchpad Windows Precision Touchpad Driver Implementation for Apple MacBook / Magic Trackpad 项目地址: https://gitcode.com/gh_mirrors/ma/mac-precision-touchpad…...

梓梦-外用制剂粒度分析仪在阿昔洛韦乳膏中的粒度测试应用

外用乳膏剂的质量直接关系到临床疗效与用药安全,其中粒度分布是核心质控指标之一,直接影响药物的透皮吸收效率、稳定性及刺激性。阿昔洛韦乳膏作为临床常用的抗病毒外用制剂,其粒度控制需严格遵循《中国药典》规范,药典明确规定&a…...

Nomacs图像查看器:从安装到高级使用的完整指南

Nomacs图像查看器:从安装到高级使用的完整指南 【免费下载链接】nomacs nomacs is a free image viewer for windows, linux, and mac systems. 项目地址: https://gitcode.com/gh_mirrors/no/nomacs Nomacs是一款免费开源的跨平台图像查看器,支持…...