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

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.4 可视化报告输出

👉 点击关注不迷路
👉 点击关注不迷路
👉 点击关注不迷路


文章大纲

  • 电商数据分析实战:基于PostgreSQL的可视化报告生成全流程
    • 9.4 可视化报告输出
      • 9.4.1 可视化报告设计框架
        • 9.4.1.1 报告目标与受众
        • 9.4.1.2 数据准备与指标体系
      • 9.4.2 动态报表生成实战
        • 9.4.2.1 数据获取与清洗
        • 9.4.2.2 Jupyter Notebook交互式分析
        • 9.4.2.3 ReportLab生成PDF报告
      • 9.4.3 核心可视化图表解析
        • 9.4.3.1 销售趋势分析
        • 9.4.3.2 用户行为分析
        • 9.4.3.3 产品表现分析
      • 9.4.4 自动化报告发布机制
      • 9.4.5 报告解读与业务建议
        • 9.4.5.1 核心结论
        • 9.4.5.2 行动建议
      • 9.4.6 报告质量控制
    • 总结

电商数据分析实战:基于PostgreSQL的可视化报告生成全流程

9.4 可视化报告输出

在电商数据分析的全流程中,可视化报告是将数据洞察转化为业务决策的关键环节。

  • 通过清晰、直观的图表和数据展示,不仅能帮助业务团队快速理解核心结论,还能为后续的策略优化提供数据支撑。
  • 本节将结合PostgreSQL数据处理结果,通过Jupyter Notebook和ReportLab工具生成动态PDF报告,覆盖销售趋势、用户行为、产品表现等核心分析维度。
    在这里插入图片描述

9.4.1 可视化报告设计框架

9.4.1.1 报告目标与受众
  • 核心目标:通过数据可视化揭示销售规律、用户偏好及运营问题,支持精准营销、库存优化和风险防控。
  • 受众定位
    • 管理层关注GMV增长、用户分层和营销ROI等宏观指标。
      • GMV(Gross Merchandise Volume)即商品交易总额,是电商领域常用的指标,用来衡量一段时间内的销售规模。
        • GMV = 销售单价 × 销售数量 + 取消订单金额 + 退货订单金额 + 拒收订单金额
          • 例如,一家电商平台在一个月内,成功销售商品的金额为 80 万元,取消订单涉及金额 5 万元,退货订单金额 3 万元,拒收订单金额 2 万元,那么该月的 GMV = 80 + 5 + 3 + 2 = 90 万元。
        • 局限性
          • 不能反映实际收入: 由于包含取消、退货等订单金额,GMV 并不能准确反映电商平台或商家的实际收入。
          • 可能存在刷单等虚假交易: 部分商家为了提升 GMV 可能会进行刷单等虚假交易,导致 GMV 数据失真。因此,在分析 GMV 时,需要结合其他指标和数据进行综合评估。
    • 运营团队:需细化到产品销售趋势、地域分布和促销效果。
    • 技术团队:侧重数据清洗流程和自动化报表生成机制。
9.4.1.2 数据准备与指标体系

构建的电商数据库(包含fact_ordersdim_productsdim_users等表),核心分析指标如下:

指标分类具体指标PostgreSQL计算示例
销售指标总销售额(GMV)SUM(order_amount)
平均订单价AVG(order_amount)
销售增长率LAG(order_amount) OVER (ORDER BY sale_month)
用户行为转化率COUNT(DISTINCT user_id) / COUNT(DISTINCT session_id)
购物车放弃率1 - (COUNT(DISTINCT order_id) / COUNT(DISTINCT cart_id))
产品表现热销商品Top10product_id, SUM(order_quantity) DESC LIMIT 10
库存周转率SUM(order_quantity) / AVG(stock_quantity)
风险控制异常订单占比COUNT(*) FILTER (WHERE is_anomaly = TRUE) / COUNT(*)
  • 建表语句
    CREATE TABLE IF NOT EXISTS fact_orders (order_id BIGSERIAL PRIMARY KEY,  -- 自增订单ID(主键)order_time TIMESTAMP NOT NULL,    -- 订单时间(精确到秒)product_id INTEGER NOT NULL,      -- 产品ID(关联产品表)order_amount DECIMAL(10,2) NOT NULL CHECK (order_amount > 0),  -- 订单金额(保留2位小数)payment_status VARCHAR(20) NOT NULL CHECK (payment_status IN ('正常', '异常')),  -- 支付状态return_rate DECIMAL(5,2) NOT NULL CHECK (return_rate BETWEEN 0 AND 1),  -- 退货率(0-1)fraud_score DECIMAL(3,2) NOT NULL CHECK (fraud_score BETWEEN 0 AND 1)  -- 欺诈分数(0-1)
    );-- 插入 100 条测试数据(覆盖 2023-2025 年数据,用于同比分析)
    INSERT INTO fact_orders (order_time, product_id, order_amount, payment_status, return_rate, fraud_score)
    SELECT order_time,product_id,order_amount,payment_status,-- 此时 payment_status 已在子查询中生成,可以安全引用CASE WHEN payment_status = '正常' THEN (random() * 0.2)::DECIMAL(5,2)ELSE (random() * 0.3 + 0.2)::DECIMAL(5,2)END AS return_rate,random()::DECIMAL(3,2) AS fraud_score
    FROM (-- 子查询先生成 payment_status,再供外层计算 return_rateSELECTDATE '2023-01-01' + (random() * (DATE '2025-04-30' - DATE '2023-01-01'))::INTEGER * INTERVAL '1 day'+ (random() * 86400)::INTEGER * INTERVAL '1 second' AS order_time,(random() * 4 + 1)::INTEGER AS product_id,(random() * 990 + 10)::DECIMAL(10,2) AS order_amount,CASE WHEN random() < 0.9 THEN '正常' ELSE '异常' END AS payment_statusFROM GENERATE_SERIES(1, 100)
    ) subquery;  -- 子查询先生成 payment_status 列
    

9.4.2 动态报表生成实战

9.4.2.1 数据获取与清洗

通过PostgreSQL存储过程实现数据自动化处理,以下为关键SQL片段:

-- 计算月度销售数据(带同比分析)
-- 步骤1:如果存在同名表,先删除(避免与视图名称冲突)
DROP TABLE IF EXISTS monthly_sales;-- 步骤2:创建或替换视图(确保目标对象是视图)
CREATE OR REPLACE VIEW monthly_sales AS
SELECTDATE_TRUNC('month', order_time)::DATE AS sale_month,product_id,SUM(order_amount) AS total_sales,LAG(SUM(order_amount), 12) OVER (PARTITION BY product_id ORDER BY DATE_TRUNC('month', order_time)::DATE) AS sales_12m_ago,ROUND((SUM(order_amount) / LAG(SUM(order_amount), 12) OVER (PARTITION BY product_id ORDER BY DATE_TRUNC('month', order_time)::DATE)) * 100 - 100, 2) AS sales_growth_rate
FROM fact_orders
GROUP BY 1, 2;-- 识别高风险订单
CREATE OR REPLACE VIEW risk_orders AS
SELECTorder_id,CASEWHEN payment_status = '异常' AND return_rate > 0.3 THEN '高风险'WHEN fraud_score > 0.8 THEN '疑似欺诈'ELSE '正常'END AS risk_level
FROM fact_orders;

在这里插入图片描述

9.4.2.2 Jupyter Notebook交互式分析

使用Matplotlib和ipywidgets库实现动态可视化:

# 导入依赖库
import psycopg2
import pandas as pd
import matplotlib.pyplot as plt
import ipywidgets as widgets
from IPython.display import display# 连接PostgreSQL获取数据
conn = psycopg2.connect(dbname="postgres",user="postgres",password="postgres",host="192.168.232.128",port="5432"
)
monthly_sales = pd.read_sql("SELECT * FROM monthly_sales", conn)# 动态折线图:产品销售趋势
def plot_sales_trend(product_id):filtered_data = monthly_sales[monthly_sales['product_id'] == product_id]plt.figure(figsize=(12, 6))plt.plot(filtered_data['sale_month'], filtered_data['total_sales'], marker='o', color='#2B6CB0')plt.title(f"Product {product_id} Sales Trend", fontsize=14)plt.xlabel("Month", fontsize=12)plt.ylabel("Total Sales (USD)", fontsize=12)plt.grid(True)plt.show()# 交互式下拉菜单
product_dropdown = widgets.Dropdown(options=monthly_sales['product_id'].unique(),description='Select Product:',layout={'width': '200px'}
)
product_dropdown.observe(lambda change: plot_sales_trend(change['new']), names='value')display(product_dropdown)
9.4.2.3 ReportLab生成PDF报告

通过Python脚本生成结构化PDF文档,支持中文字体和复杂排版:

from reportlab.lib import colors
from reportlab.lib.pagesizes import A4, landscape
from reportlab.lib.styles import getSampleStyleSheet, ParagraphStyle
from reportlab.lib.units import cm
from reportlab.platypus import (SimpleDocTemplate, Paragraph, Spacer, Table, TableStyle, Image, PageBreak)
from reportlab.pdfbase import pdfmetrics
from reportlab.pdfbase.ttfonts import TTFont
import os# ---------------------- 字体配置(兼容多系统) ----------------------
def get_chinese_font():"""自动检测系统字体路径,优先使用系统自带中文字体"""font_paths = [# Windows 宋体路径os.path.join(os.environ.get('WINDIR', 'C:\\Windows'), 'Fonts', 'simsun.ttc'),# Linux 思源宋体(常见服务器字体)'/usr/share/fonts/opentype/noto/NotoSansCJK-Regular.ttc',# macOS 苹方字体'/System/Library/Fonts/PingFang.ttc']for path in font_paths:if os.path.exists(path):return pathraise FileNotFoundError("未找到系统中文字体,请手动指定字体路径")# 注册中文字体(自动检测系统字体)
pdfmetrics.registerFont(TTFont('ChineseFont', get_chinese_font()))# 自定义样式表(覆盖默认样式)
styles = getSampleStyleSheet()
styles.add(ParagraphStyle(name='Title',fontName='ChineseFont',fontSize=24,leading=30,alignment=1,  # 居中对齐spaceAfter=20  # 标题后间距
))
styles.add(ParagraphStyle(name='Section',fontName='ChineseFont',fontSize=18,textColor=colors.darkblue,leading=24,spaceBefore=15,spaceAfter=10
))
styles.add(ParagraphStyle(name='Body',fontName='ChineseFont',fontSize=12,leading=18,alignment=0,  # 左对齐spaceAfter=8
))# ---------------------- 模拟业务数据 ----------------------
sales_data = [["月份", "销售额(万元)", "同比增长率"],["2024-01", "128.5", "15.2%"],["2024-02", "112.3", "12.1%"],["2024-03", "145.6", "18.7%"],["2024-04", "139.2", "16.3%"]
]# ---------------------- PDF内容构建 ----------------------
doc = SimpleDocTemplate("ecommerce_report.pdf", pagesize=A4, leftMargin=2*cm, rightMargin=2*cm,topMargin=2.5*cm, bottomMargin=2*cm)
elements = []# 封面页
elements.append(Paragraph("2024年电商运营分析报告", styles['Title']))
elements.append(Spacer(1, 5*cm))  # 垂直间距
elements.append(Paragraph("数据日期:2024-01至2024-04", styles['Body']))
elements.append(PageBreak())  # 分页# 销售概览章节
elements.append(Paragraph("一、销售概览", styles['Section']))
elements.append(Paragraph("本季度整体销售保持稳定增长,核心品类贡献主要营收...", styles['Body']))# 插入表格(带样式)
table = Table(sales_data, colWidths=[4*cm, 4*cm, 4*cm])
table.setStyle(TableStyle([('FONTNAME', (0,0), (-1,-1), 'ChineseFont'),  # 全局中文字体('FONTSIZE', (0,0), (-1,0), 12),  # 表头字号('BACKGROUND', (0,0), (-1,0), colors.lightblue),  # 表头背景('TEXTCOLOR', (0,0), (-1,0), colors.white),  # 表头文字颜色('ALIGN', (0,0), (-1,-1), 'CENTER'),  # 居中对齐('BOTTOMPADDING', (0,0), (-1,0), 10),  # 表头内边距('GRID', (0,0), (-1,-1), 0.5, colors.grey)  # 表格线
]))
elements.append(table)
elements.append(Spacer(1, 1*cm))  # 表格后间距# 插入图片(销售趋势图)
try:# 假设当前目录有趋势图(可替换为实际图片路径)img = Image("sales_trend.png", width=15*cm, height=8*cm)elements.append(img)
except FileNotFoundError:elements.append(Paragraph("注:销售趋势图缺失,请检查图片路径", styles['Body']))# 结论章节
elements.append(PageBreak())  # 新页
elements.append(Paragraph("二、结论与建议", styles['Section']))
elements.append(Paragraph("1. 建议Q2加大促销力度提升四月转化率...", styles['Body']))
elements.append(Paragraph("2. 重点关注三月高增长品类的供应链稳定性...", styles['Body']))# 生成PDF
doc.build(elements) 

9.4.3 核心可视化图表解析

9.4.3.1 销售趋势分析
  • 柱状图:对比不同品类销售额占比,突出3C数码(38%)和美妆(27%)为核心品类。
品类销售额(万元)占比
3C数码128038%
美妆92027%
家居65019%
其他45016%
9.4.3.2 用户行为分析
  • 漏斗图:展示用户从浏览到支付的转化路径,发现支付环节流失率高达32%(图9-2)。
  • 热力图:按地域分布显示订单密度,广东(18%)、浙江(15%)、江苏(12%)为Top3省份(图9-3)。
9.4.3.3 产品表现分析
  • 散点图:以销量为X轴、利润率为Y轴,定位高利润低销量的潜力产品(如SKU-007)和高销量低利润的引流产品(如SKU-012)。
  • 雷达图:综合评估产品的复购率、好评率、库存周转率等维度,识别综合表现优异的明星产品(图9-4)。

9.4.4 自动化报告发布机制

通过pg_cron扩展实现月度报告自动生成:

-- 安装pg_cron
CREATE EXTENSION pg_cron;-- 每月1日凌晨3点执行报告生成脚本
SELECT cron.schedule('monthly_report_job','0 3 1 * *',$$python /scripts/generate_report.py$$
);

9.4.5 报告解读与业务建议

9.4.5.1 核心结论
    1. 销售增长:Q4 GMV同比提升22%,但客单价环比下降8%,需优化促销策略。
    1. 用户留存:新客占比65%,但30日留存率仅28%,需加强会员体系建设。
    1. 产品优化:Top10热销商品贡献58%销售额,但其中3款库存周转率低于行业均值。
9.4.5.2 行动建议
  • 营销层面:针对高价值用户(RFM模型前10%)推送专属折扣,提升复购率。
  • 运营层面:对库存周转率低的商品启动清仓活动,同时增加潜力产品的曝光。
  • 技术层面:优化支付接口响应速度,降低支付环节流失率。

9.4.6 报告质量控制

    1. 数据验证:通过Grafana监控数据质量指标(缺失率<5%、异常值占比<2%)
    1. 版本管理:使用Git跟踪报告生成脚本的变更历史。
    1. 权限控制:敏感数据(如用户手机号)采用脱敏处理,仅管理层可访问原始数据

总结

通过PostgreSQL与可视化工具的深度结合,本案例实现了从数据清洗到动态报告生成的全流程自动化。

  • 报告不仅覆盖销售、用户、产品等核心维度,
    还通过交互式图表和自动化机制提升了数据洞察的时效性和可操作性。
  • 企业可在此基础上进一步扩展,例如引入机器学习模型进行销售预测,或集成BI工具实现实时数据监控,持续深化数据驱动的业务决策能力。

相关文章:

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.4 可视化报告输出

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 电商数据分析实战&#xff1a;基于PostgreSQL的可视化报告生成全流程9.4 可视化报告输出9.4.1 可视化报告设计框架9.4.1.1 报告目标与受众9.4.1.2 数据准备与指标体系 9.4.2…...

字符串---Spring字符串基本处理

一、String类的特性 不可变性 String对象一旦创建&#xff0c;内容不可更改&#xff0c;任何修改操作都会生成新对象。字符串常量池 字符串字面量&#xff08;如"abc"&#xff09;直接存储在常量池中&#xff0c;重复字面量共享同一内存地址。创建方式 虽然都是字符…...

车载以太网转USB接口工具选型指南(2025版)

一、车载以太网转USB接口工具的核心需求 在新能源汽车研发中&#xff0c;车载以太网与USB接口的转换工具需满足以下核心需求&#xff1a; 物理层兼容性&#xff1a;支持100BASE-T1/1000BASE-T1车载以太网标准&#xff0c;适应车内EMC环境。协议解析能力&#xff1a;支持SOME/…...

Docker基础入门:容器化技术详解

Docker基础入门&#xff1a;容器化技术详解 1. Docker简介 Docker是一个开源的容器化平台&#xff0c;它允许开发者将应用及其依赖打包到一个可移植的容器中&#xff0c;从而确保应用在不同环境中的一致运行。Docker于2013年发布&#xff0c;迅速成为软件开发领域的革命性工具…...

SQL注入的绕过方式

1.注释与空白符绕过 利用#,--,/**/替代被过滤的注释符 利用%09&#xff08;Tab&#xff09;,%0A(换行) &#xff0c;/**/代替空格&#xff1a;如union%0Aselect%0A1,2,3 2.编码绕过&#xff1a; URL编码&#xff0c;双重编码&#xff0c;十六进制编码&#xff0c;Unicode编…...

Java 23种设计模式 - 结构型模式7种

Java 23种设计模式 - 结构型模式7种 1 适配器模式 适配器模式把一个类的接口变换成客户端所期待的另一种接口&#xff0c;从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。 优点 将目标类和适配者类解耦增加了类的透明性和复用性&#xff0c;将具体的实现封…...

Linux快速入门

Linux概述 Linux系统版本 Linux系统分为内核版和发行版 内核版 由Linux核心团队开发、维护 免费、开源 负责控制硬件 发行版 基于Linux内核版进行扩展 由各个Linux厂商开发、维护 有收费版本和免费版本 Linux系统发行版&#xff1a; Ubuntu:以桌面应用为主&#xff0c;免费 …...

了解Hadoop

Hadoop了解 Hadoop 是 Apache 基金会开发的一个开源分布式计算平台&#xff0c;主要用于存储和处理大规模数据集。 它能让用户在不了解分布式系统底层细节的情况下&#xff0c;轻松进行分布式程序的开发&#xff0c;将应用程序自动部署到由大量普通机器组成的集群上进行高效运…...

FPGA:如何提高RTL编码能力?

要提升RTL&#xff08;寄存器传输级&#xff09;编码能力&#xff0c;需从硬件设计思维建立、典型电路建模、编码规范掌握、工具链应用和工程实践五个维度系统性训练。以下是具体提升路径&#xff1a; 一、建立硬件设计思维&#xff1a;理解RTL与软件的本质区别 RTL代码最终会…...

高频微服务面试题总结

微服务基础概念 什么是微服务架构? 将单一应用拆分为一组小型服务每个服务运行独立进程,轻量级通信独立开发、部署和扩展特点:松耦合、独立技术栈、独立数据库微服务与单体架构对比 维度单体架构微服务架构开发效率初期快初期慢部署整体部署独立部署扩展性整体扩展细粒度扩展…...

【RAG】Milvus、Pinecone、PgVector向量数据库索引参数优化

Milvus 、PgVector 索引参数优化 IVF类索引关键参数&#xff08;基于聚类算法&#xff09; nlist (倒排列表数量): 决定将向量空间划分为多少个聚类中心值越大搜索越精确但耗时越长推荐值: 通常设置为数据量的4√n到n/1000之间例如: 1百万数据量可设nlist1000到4000 nprobe (…...

基金基础知识-指数基金 | 投资理财(4) 【待续】

基金通常是由股票、债券等多种资产组合而成的投资工具​​&#xff0c;核心是分散化&#xff0c;将资金投向一篮子资产&#xff08;动态&#xff09;&#xff0c;避免单一资产的风险。 按投资标的分类&#xff1a; 基金类型 相当于 特点 适合人群 货币基金 活期钱包&…...

【K8S系列】Kubernetes常用 命令

以下为的 Kubernetes 超全常用命令文档&#xff0c;涵盖集群管理、资源操作、调试排错等核心场景&#xff0c;结合示例与解析&#xff0c; 高效运维 Kubernetes 环境。 一、集群与节点管理 1. 集群信息查看 查看集群基本信息kubectl cluster-info # 显示API Server、DNS等核…...

高性能编程相关

​​​​​​​常见高性能编程技巧&#xff1a; 一&#xff0c;系统级性能优化&#xff1a;从系统架构设计考虑&#xff0c;例如消息队列&#xff0c;模块分成分级&#xff0c;IO读写带宽等 二&#xff0c;算法级性能优化&#xff1a;时间和空间优化 三&#xff0c;代码级性能优…...

使用 NV‑Ingest、Unstructured 和 Elasticsearch 处理非结构化数据

作者&#xff1a;来自 Elastic Ajay Krishnan Gopalan 了解如何使用 NV-Ingest、Unstructured Platform 和 Elasticsearch 为 RAG 应用构建可扩展的非结构化文档数据管道。 Elasticsearch 原生集成了行业领先的生成式 AI 工具和提供商。查看我们的网络研讨会&#xff0c;了解如…...

k8s之statefulset

什么是statefulset(sts) statefulset是用来管理有状态应用的工作负载API对象,也是一种工作负载资源 有状态和无状态 无状态应用:当前应用不会记录状态(网络可能会变、挂载的东西可能会变、顺序可能会变) 有状态应用:需要记录当前状态(网络不变、存储不变、顺序不变) 使…...

在自然语言处理任务中,像 BERT 这样的模型会在输入前自动加上一些特殊token

&#x1f331; 1. 什么是 BERT&#xff1f; BERT 是一个自然语言理解模型。你可以把它想象成一个超级聪明的“语言理解机器人”。你把一句话丢进去&#xff0c;它能&#xff1a; 理解这句话的意思&#xff1b;告诉你哪个词是实体&#xff08;人名、地名&#xff09;&#xff…...

java学习笔记

Java 方法返回值 Java 是一种强类型语言,方法在定义时必须明确指定返回值的类型。 这确保了类型安全和代码的可预测性. 方法返回值不能缺省。 必须显式声明返回类型. 如果方法没有返回值,需要使用 void 关键字来表示。 void 意味着该方法执行某些操作但不返回任何值。 访问修…...

动态规划--两个数组的dp问题

目录 1 最长公共子序列 2 最长回文子序列 3 不相交的线 4 不同的子序列 5 通配符匹配 6 正则表达式匹配 7 交错字符串 8 两个字符串的最小ASCII删除和 9 最长重复子数组 本文主要讲解两个数组的动态规划问题的几个经典例题&#xff0c;希望看完本文之后能够对大家做这…...

Xcavate 上线 Polkadot |开启 Web3 房地产投资新时代

在传统资产 Tokenization 浪潮中&#xff0c;Xcavate 以房地产为切口迅速崛起。作为 2023 年 OneBlock 冬季波卡黑客松冠军&#xff0c;Xcavate 凭借创新的资产管理与分发机制&#xff0c;在波卡生态中崭露头角。此次主网上线&#xff0c;标志着 Xcavate 正式迈入全球化应用阶段…...

在企业级项目中高效使用 Maven-mvnd

1、引言 1.1 什么是 Maven-mvnd? Maven-mvnd 是 Apache Maven 的一个实验性扩展工具(也称为 mvnd),基于守护进程(daemon)模型构建,目标是显著提升 Maven 构建的速度和效率。它由 Red Hat 推出,通过复用 JVM 进程来减少每次构建时的启动开销。 1.2 为什么企业在构建过…...

[论文阅读]Deeply-Supervised Nets

摘要 我们提出的深度监督网络&#xff08;DSN&#xff09;方法在最小化分类误差的同时&#xff0c;使隐藏层的学习过程更加直接和透明。我们尝试通过研究深度网络中的新公式来提升分类性能。我们关注卷积神经网络&#xff08;CNN&#xff09;架构中的三个方面&#xff1a;&…...

使用零样本LLM在现实世界环境中推广端到端自动驾驶——论文阅读

《Generalizing End-To-End Autonomous Driving In Real-World Environments Using Zero-Shot LLMs》2024年12月发表&#xff0c;来自纽约stony brook大学、UIC和桑瑞思&#xff08;数字化医疗科技公司&#xff09;的论文。 传统的自动驾驶方法采用模块化设计&#xff0c;将任务…...

多视图密集对应学习:细粒度3D分割的自监督革命

原文标题&#xff1a;Multi-view Dense Correspondence Learning (MvDeCor) 引言 在计算机视觉与图形学领域&#xff0c;3D形状分割一直是一个基础且具有挑战性的任务。如何在标注稀缺的情况下&#xff0c;实现对3D模型的细粒度分割&#xff1f;近期&#xff0c;斯坦福大学视觉…...

【论文阅读】——Articulate AnyMesh: Open-Vocabulary 3D Articulated Objects Modeling

文章目录 摘要一、介绍二、相关工作2.1. 铰接对象建模2.2. 部件感知3D生成 三、方法3.1. 概述3.2. 通过VLM助手进行可移动部件分割3.3. 通过几何感知视觉提示的发音估计3.4. 通过随机关节状态进行细化 四、实验4.1. 定量实验发音估计设置: 4.2. 应用程序 五、结论六、思考 摘要…...

Docker Compose 的详细使用总结、常用命令及配置示例

以下是 Docker Compose 的详细使用总结、常用命令及配置示例&#xff0c;帮助您快速掌握这一容器编排工具。 一、Docker Compose 核心概念 定位&#xff1a;用于定义和管理多容器 Docker 应用&#xff0c;通过 YAML 文件配置服务、网络、卷等资源。核心概念&#xff1a; 服务 …...

2025.05.08-得物春招研发岗-第三题

📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 03. 矩阵魔法变换 问题描述 A先生是一位著名的魔法师,他最近发明了一种特殊的矩阵魔法。这种魔法可以同时改变矩阵中特定区域内所有元素的值。 A先生有一个 n m n \times m...

【Spring AI 实战】基于 Docker Model Runner 构建本地化 AI 聊天服务:从配置到函数调用全解析

【Spring AI 实战】基于 Docker Model Runner 构建本地化 AI 聊天服务&#xff1a;从配置到函数调用全解析 前沿&#xff1a;本地化 AI 推理的新范式 随着大语言模型&#xff08;LLM&#xff09;应用的普及&#xff0c;本地化部署与灵活扩展成为企业级 AI 开发的核心需求。Do…...

【数据机构】2. 线性表之“顺序表”

- 第 96 篇 - Date: 2025 - 05 - 09 Author: 郑龙浩/仟墨 【数据结构 2】 文章目录 数据结构 - 2 -线性表之“顺序表”1 基本概念2 顺序表(一般为数组)① 基本介绍② 分类 (静态与动态)③ 动态顺序表的实现**test.c文件:****SeqList.h文件:****SeqList.c文件:** 数据结构 - 2 …...

Django ORM: values() 和 annotate() 方法详解

1. values()方法 1.1 基本概念 values()方法用于返回一个包含字典的QuerySet&#xff0c;而不是模型实例。每个字典表示一个对象&#xff0c;键对应于模型字段名称。 1.2 基本用法 # 获取所有书籍的标题和出版日期 from myapp.models import Bookbooks Book.objects.value…...

数据结构篇-二叉树

抽象定义CFG文法具体表示基本操作性质 抽象定义 二叉树是一个抽象的数学概念。它的定义是递归的 一棵二叉树可以是一个外部节点&#xff0c;一棵二叉树可以是内部节点&#xff0c;连接到一对二叉树&#xff0c;分别是它的左子树&#xff0c;和右子树。 这个抽象定义描述了二…...

前端面试每日三题 - Day 29

这是我为准备前端/全栈开发工程师面试整理的第29天每日三题练习&#xff1a; ✅ 题目1&#xff1a;Web Components技术全景解析 核心三要素 Custom Elements&#xff08;自定义元素&#xff09; class MyButton extends HTMLElement {constructor() {super();this.attachShado…...

Java设计模式之抽象工厂模式:从入门到精通

一、抽象工厂模式概述 抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。 1.1 专业定义 抽象工厂模式定义了一个工厂接口,用于创建一系列相关或依赖的对象,客户端通过调用抽象工…...

Rust中记录日志:fast_log

在Rust程序中记录日志&#xff0c;可以使用fast_log。 根据fast_log 的介绍&#xff0c;这是一个性能非常高的日志实现&#xff0c;还支持文件追加模式、压缩、切分与回滚等操作。 而且&#xff0c;这个库记录日志是异步的&#xff0c;即不会因为日志而影响程序的运行。只有当…...

构筑芯片行业的“安全硅甲”

在半导体行业&#xff0c;数据就是生命线。一份芯片设计图纸的泄露&#xff0c;可能让企业数亿研发投入付诸东流&#xff1b;一段核心代码的外传&#xff0c;甚至可能影响国家产业安全。然而&#xff0c;现实情况却是——许多芯片企业的数据防护&#xff0c;仍处于“裸奔”状态…...

C++ Dll创建与调用 查看dll函数 MFC 单对话框应用程序(EXE 工程)改为 DLL 工程

C Dll创建 一、添加 DllMain&#xff08;必要&#xff09; #include <fstream>void Log(const char* msg) {std::ofstream f("C:\\temp\\dll_log.txt", std::ios::app);f << msg << std::endl; }BOOL APIENTRY DllMain(HMODULE hModule, DWORD u…...

使用智能表格做FMEDA

一、优点 使用智能表格替代excel做FMEDA具备以下优势&#xff1a; 减少维护成本&#xff08;数据库关联&#xff0c;修改方便&#xff09;便于持续优化&#xff08;失效率分布&#xff0c;失效率模型可重复使用&#xff09;多人同步编写&#xff08;同时操作&#xff0c;同步…...

电动汽车充换电设施可调能力聚合评估与预测 - 使用说明文档

电动汽车充换电设施可调能力聚合评估与预测 - 使用说明文档 概述 本脚本real_data_model.m基于论文《大规模电动汽车充换电设施可调能力聚合评估与预测》(鲍志远&#xff0c;胡泽春)实现了电动汽车充电设施的负荷预测和可调能力评估。使用混合模型&#xff08;LSTM神经网络线…...

Tomcat 日志体系深度解析:从访问日志配置到错误日志分析的全链路指南

一、Tomcat 核心日志文件架构与核心功能 1. 三大基础日志文件对比&#xff08;权威定义&#xff09; 日志文件数据来源核心功能典型场景catalina.out标准输出 / 错误重定向包含 Tomcat 引擎日志与应用控制台输出&#xff08;System.out/System.err&#xff09;排查 Tomcat 启…...

MSF 生成不同的木马 msfvenom 框架命令

目录 什么是 msfvenom&#xff1f; 一、针对 Windows 的木马生成命令 1. EXE 格式&#xff08;经典可执行文件&#xff09; 2. VBS 脚本&#xff08;Visual Basic Script&#xff09; 3. PowerShell 脚本 4. DLL 文件&#xff08;动态链接库&#xff09; 5. Python 脚本…...

Linux云计算训练营笔记day05(Rocky Linux中的命令:管道操作 |、wc、find、vim)

管道操作 | 作用: 将前面命令的输出&#xff0c;传递给后面命令&#xff0c;作为后面命令的参数 head -3 /etc/passwd | tail -1 取第三行 head -8 /etc/passwd | tail -3 | cat -n 取6 7 8行 ifconfig | head -2 | tail -1 只查看IP地址 ifconfig | grep 192 过滤192的ip…...

【相机标定】OpenCV 相机标定中的重投影误差与角点三维坐标计算详解

摘要&#xff1a; 本文将从以下几个方面展开&#xff0c;结合典型代码深入解析 OpenCV 中的相机标定过程&#xff0c;重点阐述重投影误差的计算方法与实际意义&#xff0c;并通过一个 calcBoardCornerPositions() 函数详细讲解棋盘格角点三维坐标的构建逻辑。 在计算机视觉领域…...

传统销售VS智能销售:AI如何重构商业变现逻辑

如今最会赚钱的企业早就不靠堆人力了&#xff0c;他们都在悄悄用AI做商业变现。当普通销售还在手动记录客户信息时&#xff0c;AI销售系统已经能实时追踪客户在商品页的停留时长&#xff0c;甚至精确到秒。 传统客服人员还在机械地复制粘贴标准话术&#xff0c;AI销售却已经能根…...

从设计到开发,原型标注图全流程标准化

一、原型标注图是什么&#xff1f; 原型标注图&#xff08;Annotated Prototype&#xff09;是设计原型&#xff08;Prototype&#xff09;的详细说明书&#xff0c;通过图文结合的方式&#xff0c;将设计稿中的视觉样式、交互逻辑、适配规则等技术细节转化为开发可理解的标准…...

Mac QT水平布局和垂直布局

首先上代码 #include "mainwindow.h" #include "ui_mainwindow.h" #include <QPushButton> #include<QVBoxLayout>//垂直布局 #include<QHBoxLayout>//水平布局头文件 MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), …...

部署Superset BI(四)连接sql server数据库

sqlserver没有出现在Superset的连接可选菜单上&#xff0c;这一点让我奇怪。既然没有那就按着HANA的配置方式&#xff0c;照猫画虎。更奇怪的是安装好还不能出现&#xff0c;难道superset和微软有仇&#xff1f; --修改配置文件 rootNocobase:/usr/superset/superset# cd docke…...

Python爬虫(22)Python爬虫进阶:Scrapy框架动态页面爬取与高效数据管道设计

目录 一、背景&#xff1a;Scrapy在现代爬虫中的核心价值二、Scrapy项目快速搭建1. 环境准备与项目初始化2. 项目结构解析 三、动态页面处理&#xff1a;集成Splash与中间件1. 配置Splash渲染服务&#xff08;Docker部署&#xff09;2. 修改settings.py启用中间件3. 在Spider中…...

全球实物文件粉碎服务市场洞察:合规驱动下的安全经济与绿色转型

一、引言&#xff1a;从纸质堆叠到数据安全的“最后一公里” 在数字化转型浪潮中&#xff0c;全球企业每年仍产生超过1.2万亿页纸质文件&#xff0c;其中包含大量机密数据、客户隐私及商业敏感信息。据QYResearch预测&#xff0c;2031年全球实物文件粉碎服务市场规模将达290.4…...

使用Python 打造多格式文件预览工具 — 图、PDF、Word、Excel 一站式查看

在日常办公或文件管理场景中&#xff0c;我们经常面临这样的问题&#xff1a;在一个文件夹中短时间内产生了大量不同类型的文件&#xff08;如图片、PDF、Word、Excel&#xff09;&#xff0c;我们需要快速浏览和筛选这些文件的内容&#xff0c;却不希望一个个打开它们。有没有…...

Microsoft 365 Copilot:为Teams在线会议带来多语言语音交流新体验

随着AI技术的飞速发展&#xff0c;Microsoft 365 Copilot将大型语言模型&#xff08;LLM&#xff09;与业务数据深度融合&#xff0c;为用户带来了前所未有的办公体验。在Teams在线会议中&#xff0c;Copilot不仅能够作为智能助手提升会议效率&#xff0c;还能通过实时辅助同声…...