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

ES练习册

es索引结构和数据实例

这里提供索引结构和数据实例提供给大家使用练习,希望大家能够一起成长进步~~~~

#添加索引
PUT /ecommerce_products
{"settings": {"number_of_shards": 3,"number_of_replicas": 1,"analysis": {"analyzer": {"custom_lowercase": {"type": "custom","tokenizer": "standard","filter": ["lowercase"]}}}},"mappings": {"dynamic": "strict","properties": {"product_id": { "type": "keyword" }, "name": {"type": "text","fields": {"keyword": { "type": "keyword", "ignore_above": 256 }},"analyzer": "custom_lowercase"},"description": { "type": "text" },"price": { "type": "scaled_float", "scaling_factor": 100 },"in_stock": { "type": "boolean" },"categories": { "type": "keyword" },"tags": {"type": "keyword","eager_global_ordinals": true},"created_at": { "type": "date","format": "strict_date_optional_time||epoch_millis"},"last_updated": { "type": "date" },"rating": { "type": "half_float" },"reviews": {"type": "nested","properties": {"user_id": { "type": "keyword" },"score": { "type": "byte" },"comment": { "type": "text" },"created_at": { "type": "date" },"responses": {"type": "nested","properties": {"admin_id": { "type": "keyword" },"response_text": { "type": "text" }}}}},"warehouse_location": { "type": "geo_point" },"supplier_info": {"properties": {"name": { "type": "keyword" },"ip_address": { "type": "ip" }}},"suggest": { "type": "completion" },"attributes": {"type": "object","dynamic": true},"name_translations": {"type": "object","properties": {"en": { "type": "text" },"zh": { "type": "text", "analyzer": "ik_max_word" },"es": { "type": "text" }}}}}
}#查询索引
GET /ecommerce_products#添加文档数据
#POST/索引库名/_doc/文档idPOST /ecommerce_products/_doc/1
{"product_id": "P123456","name": "无线蓝牙耳机","description": "高端降噪耳机,30小时超长续航","price": 199.99,"in_stock": true,"categories": ["电子产品", "音频设备"],"tags": ["无线", "降噪", "新款"],"created_at": "2023-10-05T08:23:45Z","last_updated": "2024-02-15","rating": 4.5,"reviews": [{"user_id": "U1001","score": 5,"comment": "音质非常出色","created_at": "2023-12-01","responses": [{"admin_id": "ADM001","response_text": "感谢您的反馈!"}]}],"warehouse_location": {"lat": 40.7128,"lon": -74.0060},"supplier_info": {"name": "音科技术公司","ip_address": "192.168.1.100"},"suggest": {"input": ["耳机", "蓝牙", "无线"],"weight": 34},"attributes": {"颜色": "黑色","重量_kg": 0.25},"name_translations": {"en": "Wireless Headphones","zh": "无线蓝牙耳机","es": "Audífonos inalámbricos Bluetooth"}
}POST /ecommerce_products/_doc/2
{"product_id": "P789012","name": "智能健身手环","description": "防水运动手环,支持心率监测和睡眠追踪","price": 79.99,"in_stock": false,"categories": ["可穿戴设备", "运动健康"],"tags": ["防水", "心率监测", "入门款"],"created_at": "2023-11-20","last_updated": "2024-03-10T14:30:00","rating": 4.2,"reviews": [{"user_id": "U2002","score": 4,"comment": "性价比不错,但APP需要改进","created_at": "2024-01-15","responses": [{"admin_id": "ADM002","response_text": "我们会持续优化软件体验"}]}],"warehouse_location": "31.2304,121.4737","supplier_info": {"name": "智动科技","ip_address": "10.20.30.40"},"suggest": {"input": ["手环", "运动", "健康"],"weight": 28},"attributes": {"腕带材质": "硅胶","屏幕类型": "OLED"}
}POST /ecommerce_products/_doc/3
{"product_id": "P345678","name": "智能温控水杯","description": "支持APP控制的保温水杯,12小时长效保温","price": 149.5,"in_stock": true,"categories": ["生活家电", "智能硬件"],"tags": ["保温", "智能控制", "礼品"],"created_at": "2024-02-01T09:15:30Z","rating": 4.8,"reviews": [{"user_id": "U3003","score": 5,"comment": "冬天保持水温效果非常好","created_at": "2024-03-01","responses": []}],"warehouse_location": "22.3193,114.1694","supplier_info": {"name": "智联家居","ip_address": "172.16.0.100"},"suggest": {"input": ["水杯", "保温杯", "智能"],"weight": 42},"attributes": {"容量_ml": 500,"材质": "不锈钢"},"name_translations": {"en": "Smart Thermos Cup","zh": "智能温控水杯","es": "Taza termo inteligente"}
}POST /ecommerce_products/_doc/4
{"product_id": "P456789","name": "健康监测智能手表","description": "1.5英寸AMOLED屏,支持血氧心率监测,50米防水","price": 899.0,"in_stock": true,"categories": ["可穿戴设备", "健康监测"],"tags": ["防水", "长续航", "新品"],"created_at": "2024-03-20T10:00:00Z","rating": 4.7,"reviews": [{"user_id": "U4004","score": 5,"comment": "游泳监测非常准确","created_at": "2024-04-05","responses": [{"admin_id": "ADM003","response_text": "感谢选择我们的产品!"}]},{"user_id": "U3003","score": 5,"comment": "喜欢","created_at": "2024-04-05","responses": [{"admin_id": "ADM003","response_text": "感谢选择我们的产品!"}]}],"warehouse_location": "22.2833,114.1667",  "supplier_info": {"name": "健康科技集团","ip_address": "10.88.10.25"},"attributes": {"颜色": "曜石黑","表带材质": "氟橡胶","电池容量_mAh": 450},"name_translations": {"en": "Health Monitoring Smart Watch","zh": "健康监测智能手表","es": "Taza termo inteligente"}
}POST /ecommerce_products/_doc/5
{"product_id": "P567890","name": "静音空气净化器","description": "CADR 600m³/h,智能感应PM2.5,适用80㎡空间","price": 2499.0,"in_stock": true,"categories": ["生活家电", "环境电器"],"tags": ["智能感应", "静音"],"created_at": "2023-12-15","rating": 4.3,"reviews": [{"user_id": "U3003","score": 4,"comment": "睡眠模式确实安静","created_at": "2024-01-10","responses": []}],"warehouse_location": { "lat": 30.5728,"lon": 104.0668},  "supplier_info": {"name": "清洁科技公司","ip_address": "172.20.10.5"},"attributes": {"滤芯类型": "复合滤网","噪音分贝": 28,"适用面积_㎡": 80},"name_translations": {"en": "Health Monitoring Smart Watch","zh": "空气净化器","es": "Taza termo inteligente"}
}POST /ecommerce_products/_doc/6
{"product_id": "P678901","name": "全掌气垫跑步鞋","description": "轻量透气网面,ZOOM AIR缓震技术","price": 699.0,"in_stock": false,"categories": ["运动服饰", "鞋类"],"tags": ["促销", "限量款"],"created_at": "2024-02-28T14:30:00Z","rating": 4.6,"reviews": [{"user_id": "U6006","score": 2,"comment": "尺码偏小建议买大一码","created_at": "2024-03-15","responses": [{"admin_id": "ADM002","response_text": "已反馈给质检部门改进"}]}],"warehouse_location": "23.1291,113.2644",  "supplier_info": {"name": "运动装备制造","ip_address": "192.168.2.200"},"attributes": {"颜色": "荧光绿/黑","尺码": "42","重量_g": 320},"name_translations": {"en": "Health Monitoring Smart Watch","zh": "全掌气垫跑步鞋","es": "Taza termo inteligente"}
}POST /ecommerce_products/_doc/8
{"product_id": "P890123","name": "4K全景云台摄像头","description": "360°全景追踪,红外夜视,支持AI人形检测","price": 399.0,"in_stock": true,"categories": ["智能硬件", "安防"],"tags": ["夜视", "AI识别"],"created_at": "2024-01-10T08:00:00Z","rating": 4.0,"reviews": [{"user_id": "U8008","score": 2,"comment": "夜间画质有待提升","created_at": "2024-02-01","responses": []}],"warehouse_location": "39.9042,116.4074",  "supplier_info": {"name": "智能安防科技","ip_address": "192.168.5.100"},"attributes": {"原价": "599","存储方式": ["云存储", "本地SD卡"],"夜视距离_米": 15},"name_translations": {"en": "Health Monitoring Smart Watch","zh": "4K全景云台摄像头","es": "Taza termo inteligente"}
}#查询文档
#GET/索引库名/_doc/文档id
GET /ecommerce_products/_doc/1#增量修改文档
#POST/索引库名/_update/文档id
POST /ecommerce_products/_update/8
{"doc": {"tags": ["夜视", "AI识别","促销"]}
}

相关性算分专线练习

一、function_score 的核心作用

function_score 允许您通过自定义规则修改文档的原始相关性评分 (_score),实现以下目标:

  • 提升特定文档的排名(如促销商品、高库存商品)

  • 降低无关文档的排名(如过期内容)

  • 完全自定义排序逻辑(如结合价格、评分、时间等多因素)

二、基础语法结构

GET /索引名/_search
{"query": {"function_score": {"query": { ... },       // 主查询(基础结果集)"functions": [ ... ],   // 评分函数列表"score_mode": "sum",    // 函数评分的组合方式"boost_mode": "sum",    // 最终评分与原始评分的组合方式"max_boost": 10.0,      // 函数评分的最大限制"min_score": 2.0        // 结果过滤阈值(评分低于此值的文档被排除)}},"sort": [ { "_score": "desc" } ]
}

三、核心参数详解

1. query (主查询)
  • 作用:定义基础查询,决定哪些文档会被处理。

  • 示例:匹配所有文档或特定条件。

"query": { "match_all": {} }
2. functions (评分函数)

支持多种函数类型,可同时使用多个函数:

函数类型作用示例
weight固定权重值{ "weight": 2.0, "filter": { "term": { ... } } }
field_value_factor基于字段值的评分计算{ "field": "rating", "factor": 1.5 }
random_score随机评分(需指定种子){ "random_score": { "seed": 用户ID } }
script_score自定义脚本计算评分{ "script": "doc['price'].value * 0.1" }
decay按距离/时间衰减评分(如高斯衰减)见下文详细示例
3. score_mode (函数评分组合方式)
模式说明
sum所有函数评分相加(默认)
avg取平均值
max取最大值
min取最小值
multiply所有函数评分相乘
4. boost_mode (最终评分计算方式)
模式公式
sum最终分 = 原始分 + 函数评分
replace最终分 = 函数评分
multiply最终分 = 原始分 × 函数评分
avg最终分 = (原始分 + 函数评分)/2

 四、实战练习

#需求:
#搜索所有商品,但为有库存(in_stock=true)的商品评分增加 50% 权重,同时为评分≥4 的商品额外增加 30% 权重。最终评分按加权值排序。
GET /ecommerce_products/_search
{"query": {"function_score": {"query": {"match_all": {}},"functions": [{"filter": {"term": {"in_stock": "true"}},"weight": 1.5},{"filter": {"range": {"rating": {"gte": 4.2}}},"weight": 1.3}],"score_mode": "sum","boost_mode": "replace"}},"sort": [ { "_score": "desc" } ]
}

Aggs聚合

大白话的理解就是:

你让他aggs一下type,他就把不同类型type以及数量返回给你

一、聚合的核心概念

聚合(Aggregations) 是 Elasticsearch 中用于对数据进行统计分析的功能,类似于 SQL 的 GROUP BY + 统计函数(如 COUNTAVG)。
核心用途

  • 数据分组统计(如按分类统计商品数量)

  • 计算指标(如平均价格、最高评分)

  • 多维度交叉分析(如时间+地域的销售分布)

二、基础语法

{"aggs": {"agg_name": {"agg_type": {"field": "field_name","size": 10 (可选参数,具体取决于聚合类型)}}}
}
  • agg_name: 自定义的聚合名称,用于标识聚合结果。
  • agg_type: 聚合的类型,例如 termsavgsum 等。
  • field_name: 指定要进行聚合操作的字段。

三、常见聚合类型

Terms Aggregation (按值分组)

  • 用于根据字段的唯一值对文档进行分组。
  • 适用于分析离散值,如标签、类别等。
{"aggs": {"group_by_status": {"terms": {"field": "status.keyword"}}}
}

Range Aggregation (范围分组)

  • 用于根据数值区间对文档进行分组。
{"aggs": {"price_ranges": {"range": {"field": "price","ranges": [{ "to": 100 },{ "from": 100, "to": 200 },{ "from": 200 }]}}}
}

Date Histogram Aggregation (日期直方图)

  • 按时间间隔对文档进行分组。
{"aggs": {"sales_over_time": {"date_histogram": {"field": "sale_date","calendar_interval": "month"}}}
}

Avg, Sum, Min, Max Aggregations (统计计算)

  • 用于计算字段的平均值、总和、最小值、最大值。
{"aggs": {"average_price": {"avg": {"field": "price"}}}
}

Nested Aggregation (嵌套聚合)

  • 在嵌套字段上进行聚合。
{"aggs": {"nested_comments": {"nested": {"path": "comments"},"aggs": {"comment_authors": {"terms": {"field": "comments.author"}}}}}
}

组合聚合

  • 可以将多个聚合嵌套在一起,以得到更复杂的查询。例如,首先对一个字段进行分组,然后对每个分组进行统计计算。
{"aggs": {"group_by_status": {"terms": {"field": "status.keyword"},"aggs": {"average_price": {"avg": {"field": "price"}}}}}
}

四、实战练习

#需求:
#统计每个商品的评论回复率(有回复的评论数 / 总评论数),按回复率降序排列
GET /ecommerce_products/_search
{"size": 0,"aggs": {"products": {"nested": { "path": "reviews" },"aggs": {"total_comments": { "value_count": { "field": "reviews.user_id" } },"replied_comments": {"nested": { "path": "reviews.responses" },"aggs": { "response_count": { "value_count": { "field": "reviews.responses.admin_id" } } }}}}}
}

五、字段详解

bucket_script 

作用:对于已有的聚合结果进行二次计算,应用于计算比例、差值等

基础语法:

{"aggs": {"自定义聚合名称": {"bucket_script": {"buckets_path": {"变量1": "聚合路径1","变量2": "聚合路径2"},"script": "params.变量1 + params.变量2"}}}
}

脚本

doc['field']的通用规则

适用字段类型

  • 适用字段类型:仅适用于非文本字段(如 integerlongdoubledatekeyword 等)。

  • 不支持文本字段:如果字段是 text 类型且未设置 fielddata=true,直接访问 doc['text_field'] 会报错。

  • 返回值类型:返回一个 FieldValues 对象,需通过特定方法获取值。

常用方法

(1) .value
  • 作用:获取字段的第一个值(单值字段直接取值,多值字段取第一个值)。

  • 示例

// 单值字段:直接返回数值
double score = doc['score'].value;// 多值字段:返回第一个值(如 [80, 90] 返回 80)
int firstScore = doc['scores'].value;
(2) .values
  • 作用:获取字段的所有值(返回数组形式)。

  • 示例

// 多值字段:返回数组 [80, 90]
double[] scores = doc['scores'].values;// 遍历多值字段
for (double s : doc['scores'].values) {total += s;
}
(3) .size()
  • 作用:获取字段值的数量(单值字段返回 1,多值字段返回实际数量)。

  • 示例

if (doc['score'].size() > 0) {  // 判断字段是否存在且非空return doc['score'].value;
} else {return 0;
}
(4) .empty
  • 作用:检查字段是否为空(无值)。

  • 示例

if (!doc['score'].empty) {return doc['score'].value;
}
(5) .get(int index)
  • 作用:获取数组字段的指定索引值

  • 示例

// 获取多值字段的第二个值
if (doc['scores'].size() >= 2) {double secondScore = doc['scores'].get(1);
}
(6) .count()
  • 作用:统计字段中非空值的数量(与 .size() 不同,可能过滤空值)。

  • 示例

int validScores = doc['scores'].count();
(7) 聚合方法
  • 适用场景:对多值字段进行聚合计算。

  • 常用方法

.min()  // 最小值
.max()  // 最大值
.sum()  // 总和
.average()  // 平均值
方法用途示例场景
.value获取单值字段值或多值字段的第一个值单值数值计算
.values获取多值字段的所有值遍历求和、求平均
.size()获取值的数量(包括空值)判断字段是否为空
.empty检查字段是否为空空值保护逻辑
.get(index)获取多值字段的指定索引值访问特定位置的元素
.min()/.max()多值字段的最小值/最大值统计范围筛选

补充 

1. size().count() 和 .empty 方法

以下是针对 Elasticsearch Painless 脚本中 doc['field'] 的 .size().count() 和 .empty 方法在处理 空值、数组、字段不存在 时的具体行为示例。

示例数据

假设 Elasticsearch 中有如下文档:

{"id": 1,"name": "Alice","scores": [85, 90, null],   // 多值字段,包含 null"empty_array": [],          // 空数组"nullable_field": null      // 单值字段,值为 null
}
  • 注意:字段 missing_field 不存在

Painless 脚本示例

// 检查 scores 字段
def scores_size = doc['scores'].size();      // 返回 3
def scores_count = doc['scores'].count();    // 返回 2(过滤 null)
def scores_empty = doc['scores'].empty;      // 返回 false// 检查 empty_array 字段
def empty_array_size = doc['empty_array'].size();  // 返回 0
def empty_array_count = doc['empty_array'].count();// 返回 0
def empty_array_empty = doc['empty_array'].empty;  // 返回 true// 检查 nullable_field 字段
def nullable_size = doc['nullable_field'].size();  // 返回 1(单值 null)
def nullable_count = doc['nullable_field'].count();// 返回 0(过滤 null)
def nullable_empty = doc['nullable_field'].empty;  // 返回 false(字段存在)// 检查 missing_field 字段
def missing_size = doc['missing_field'].size();    // 抛出异常(字段不存在)
def missing_empty = doc['missing_field'].empty;    // 抛出异常(字段不存在)
字段类型.size().count().empty
多值带 null
(如 scores: [85, 90, null])
返回 总数量(含 null)
示例:3
返回 非 null 值数量
示例:2
false(存在且非空数组)
空数组
(如 empty_array: [])
00true(存在但无值)
单值 null
(如 nullable_field: null)
1(单值字段视为数组 [null])0(过滤 null)false(字段存在)
字段不存在
(如 missing_field)
报错报错报错

 2.判空处理

// 正确做法:先检查字段是否存在
if (doc.containsKey('score') && !doc['score'].empty) {return doc['score'].value;
} else {return 0;
}

相关文章:

ES练习册

es索引结构和数据实例 这里提供索引结构和数据实例提供给大家使用练习,希望大家能够一起成长进步~~~~ #添加索引 PUT /ecommerce_products {"settings": {"number_of_shards": 3,"number_of_replicas": 1,"analysis": {&…...

运算符分为哪几类?哪些运算符常用作判断?简述运算符的优先级

运算符主要分为以下几类‌: ‌算术运算符‌:用于执行基本的数学运算,如加、减、乘、除、取模等。例如:、-、*、/、%‌。‌赋值运算符‌:用于将值赋给变量。例如:、、-、*、/、%‌。‌比较运算符‌&#xff…...

shell编程基础知识及脚本示例

文章目录 前言一、shell变量1.命名规则2.定义及使用变量 二、shell传递参数1.位置参数2. 任意参数 三、shell一维数组0.定义方式1.定义并获取数组的单个元素2.定义并获取数组的所有元素3.定义并获取数组的元素个数4.定义并获取数组的元素索引 四、shell条件判断语法五、shell常…...

再学GPIO(一)

GPIO输出模式 STM32的GPIO(General Purpose Input Output 通用输入输出)引脚支持多种输出模式,不同模式决定了引脚的驱动能力和信号特性。STM32的GPIO输出模式主要分为以下4种: 推挽输出(Push-Pull Output)…...

OpenCV彩色图像分割

OpenCV计算机视觉开发实践:基于Qt C - 商品搜索 - 京东 灰度图像大多通过算子寻找边缘和区域生长融合来分割图像。彩色图像增加了色彩信息,可以通过不同的色彩值来分割图像,常用彩色空间HSV/HIS、RGB、LAB等都可以用于分割。本节使用inRange…...

django filter 排除字段

在Django中,当你使用filter查询集(QuerySet)时,通常你会根据模型的字段来过滤数据。但是,有时你可能想要排除某些特定的字段,而不是过滤这些字段。这里有几种方法可以实现这一点: 使用exclude方…...

多模态大语言模型arxiv论文略读(四十五)

CAT: Enhancing Multimodal Large Language Model to Answer Questions in Dynamic Audio-Visual Scenarios ➡️ 论文标题:CAT: Enhancing Multimodal Large Language Model to Answer Questions in Dynamic Audio-Visual Scenarios ➡️ 论文作者:Qil…...

Vue3 通过Vue3-Print-Nb在线工单打印 模板打印 自定义打印 打印下载

介绍 通过在应用中集成打印功能,用户可以直接从页面打印工单,不用导出文件或使用其他外部工具。节省时间,提高效率,特别是当需要大量打印时。同时也可以将文件模板上传到数据库,提供给部门工作自行下载。 开源文档&am…...

视觉“解锁”触觉操控:Franka机器人如何玩转刚柔物体?

集智联机器人(Plug & Play Robotics),简称PNP机器人,是Franka Robotics和思灵机器人金牌合作伙伴,集智联机器人团队成员均来自于国内外机器人行业知名企业,具有较强的学术背景。PNP机器人致力于为客户提…...

FlinkUpsertKafka深度解析

1. 设计目标与工作机制 Upsert-Kafka Connector 核心功能:支持以 Upsert(插入/更新/删除) 模式读写 Kafka 数据,适用于需要动态更新结果的场景(如聚合统计、CDC 数据同步)。数据流类型: 作为 …...

百度Create大会深度解读:AI Agent与多模态模型如何重塑未来?

目录 百度Create大会亮点全解析:从数字人到Agent生态布局 数字人商业化:从"拟人"到"高说服力"的进化 Agent生态:从"心响"App看百度的Agent战略布局 "心响"App的技术架构与创新点 多模态大模型&a…...

新能源汽车运动控制器核心芯片选型与优化:MCU、DCDC与CANFD协同设计

摘要:随着新能源汽车产业的迅猛发展,汽车运动控制器的性能和可靠性面临着更高的要求。本文深入探讨了新能源汽车运动控制器中MCU(微控制单元)、DCDC电源管理芯片和CANFD总线通信芯片的选型要点、优化策略及其协同设计方案。通过综…...

【软件工程】 白盒测试简介

1. 前言 在软件测试过程中,白盒测试(White-box Testing)是一种重要方法,它通过检查程序内部结构来验证软件功能。本文以一道典型的伪代码程序为例,结合白盒测试的基本操作,设计语句覆盖测试用例&#xff0…...

uniapp自定义一个选择年月日时分的组件。

<template><view><u-popup :show"timePopShow" mode"bottom" close"close" open"open" :closeOnClickOverlay"true"><view class"popup-container"><!-- 自定义时间内容 --><vi…...

Git命令(Gitee)

三板斧&#xff1a; git init //初始化本地仓库 git add . //添加所有文件到缓存区 &#xff08;或指定文件&#xff09; git commit -m "备注" //提交&#xff0c;填写备注 git remote add origin <远程仓库链接> git push -u origin ma…...

Node.js 应用部署:镜像体积优化与安全的多阶段构建探索

Node.js 应用部署:镜像体积优化与安全的多阶段构建探索 在开发 Node.js 应用时,部署过程中的镜像体积优化和安全性保障是至关重要的环节。本文将通过两种不同的 Docker 部署方式,深入探讨如何实现高效的镜像体积优化和安全的部署环境。 传统的单阶段构建方式 许多开发者在…...

深度解析:Web Crawling与Web Scraping的区别与联系

在现代互联网数据驱动的时代&#xff0c;Web Crawling(网页爬取)和Web Scraping(网页抓取)成为数据采集领域的两大核心技术。尽管两者常被混用&#xff0c;但它们在技术实现、应用目的和操作流程上存在显著差异。本文将基于权威资料&#xff0c;特别是维基百科的定义&#xff0…...

C# 利用log4net 工作台打印和保存到文件

目录 ‌log4net‌简介引言1、添加引用库2、添加引用和构建实例3、添加属性配置4、添加配置文件最后 ‌log4net‌简介 log4net‌是一个开源的日志记录组件&#xff0c;专为.NET平台设计。它是Apache log4j框架在Microsoft .NET平台的实现&#xff0c;属于Apache Logging Servic…...

2025 VSCode中如何进行dotnet开发环境配置完整教程

我一直都是用Visual Studio 2019来开发C#项目的&#xff0c;用的比较顺手&#xff0c;也习惯了。看其他技术文章有介绍VS Code更轻量&#xff0c;更方便。 所以就想来研究如何使用VS Code&#xff0c;看看它是如何构建代码、调试代码、如何运行C#应用程序。 本文将详细介绍如何…...

vscode本地化显示远程图形化界面

远程登陆到服务器端 sudo vim /etc/ssh/sshd_config修改文件中的参数&#xff0c;保存。主要参数如下 配置好上述后需要reload一下ssh,安装xclock。 service ssh reload # 安装x11-apps&#xff0c;这样就可以使用xclock apt install x11-apps查看环境变量,在其中并没有DISPL…...

STM32 CAN通信 HAL库实战教程:从零到测试成功

STM32 CAN通信 HAL库实战教程&#xff1a;从零到测试成功 <我打印的是陀螺仪的数据> 目录 简介&#xff1a;为什么学习CAN通信CAN通信基础概念STM32 CAN硬件配置CAN初始化详解CAN数据发送实现CAN数据接收实现测试与验证方法常见问题与解决总结与拓展 1. 简介&#xff1…...

数据结构强化篇

应用题 排序 插入排序 void InsertSort (ElemType A[], n int) {int i, j;for (i2; i<n; i) //依次将 A[2]&#xff5e;A[n]插入前面已排序序列if (A[i]<A[i-1]) { //若 A[i]关键码小于其前驱&#xff0c;将 A[i]插入有序表A[0]A[i]; //复制为哨兵&#xff0c;A[0]不存放…...

泰迪杯实战案例超深度解析:旅游景点游客流量预测与资源优化

(2025年泰迪杯数据挖掘挑战赛D题特等奖案例) 一、案例背景与目标 1.1 应用场景与痛点 某5A级景区面临以下核心问题: 拥堵严重:节假日热门景点游客密度超过10人/㎡,排队时间长达2小时。 资源浪费:接驳车空载率30%,餐饮点位在非高峰时段闲置率60%。 应急滞后:突发降雨或…...

qt 3d航迹图

一般就是三种方法 1.opengl&#xff0c;vtk这种从零自己画&#xff0c;网上也可能有半成品&#xff0c;大多是付费的。 2.重写qwt3d&#xff0c;07年就停止更新了&#xff0c;画出来类似opengl&#xff0c;需要自己修改参数&#xff0c;参数修改不对很难搞&#xff0c;对于经…...

探索排序算法的奥秘(上):冒泡排序、选择排序、插入排序

在计算机科学中&#xff0c;排序算法是数据处理的基础工具之一。通过对数据进行有序排列&#xff0c;可以极大地提高数据检索和处理的效率。本文将详细介绍三种经典的排序算法&#xff1a;冒泡排序、选择排序和插入排序。我们将从算法思想、原理、代码实现&#xff08;C语言、P…...

Stable Diffusion 技术全景解析与行业竞争力分析

目录 一、Stable Diffusion 技术概览 1. 核心背景 2. 技术架构 二、行业地位与竞品对比 1. 市场定位 2. 核心竞争优势 三、部署成本与硬件要求 1. 硬件配置方案 2. 优化技巧 四、优势与劣势分析 1. 核心优势 2. 主要劣势 五、开源策略与商业模型 1. 开源协议 2. …...

基于Python的DeepSeek API图形界面开发

基于Python的DeepSeek API图形界面开发 在人工智能技术广泛应用的今天&#xff0c;如何将强大的API能力与用户友好的界面结合&#xff0c;成为开发者关注的重点。本文将以DeepSeek API为例&#xff0c;详解如何通过Python构建兼具功能性与美观度的GUI应用程序。 一、技术架构…...

w~嵌入式C语言~合集4

我自己的原文哦~ https://blog.51cto.com/whaosoft/13870376 一、STM32怎么选型 什么是 STM32 STM32&#xff0c;从字面上来理解&#xff0c;ST是意法半导体&#xff0c;M是Microelectronics的缩写&#xff0c;32表示32位&#xff0c;合起来理解&#xff0c;STM32就是指S…...

自动驾驶(ADAS)领域常用数据集介绍

1. KITTI 数据集 简介&#xff1a;由德国卡尔斯鲁厄理工学院与丰田研究院联合创建&#xff0c;是自动驾驶领域最经典的评测基准&#xff0c;涵盖立体视觉、光流、3D检测等任务。包含市区、乡村和高速公路场景的真实数据&#xff0c;标注对象包括车辆、行人等&#xff0c;支持多…...

【嵌入式八股23】Linux关键指令

系统关机命令 在 Linux 系统中,有多种命令可用于实现系统关机或重启操作,以下为你详细介绍各命令及其特点: 指令 说明 shutdown该命令能够安全地将系统关机。它允许用户指定关机的时间,还可以在关机前向所有登录用户发送警告消息。例如,shutdown -h now 可立即关机,shu…...

机器学习的一百个概念(13)布里尔分数

前言 本文隶属于专栏《机器学习的一百个概念》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见[《机器学习的一百个概念》 ima 知识库 知识库广场搜索: 知识库创建人机器学习@Shockang机器学习数学基础@Shocka…...

AI提示词(Prompt)终极指南:从入门到精通(附实战案例)

在AI重塑工作方式的今天&#xff0c;掌握Prompt工程已成为智能时代的必备技能。本指南系统解析提示词设计精髓&#xff0c;从认知底层逻辑到实战应用技巧&#xff0c;带您解锁AI工具的完整潜能。涵盖主流模型选型策略、三大黄金法则、结构化模板及典型避坑指南&#xff0c;更有…...

鸿蒙版电影app设计开发

鸿蒙电影购票APP项目介绍 一、项目概述及使用方式 &#xff08;一&#xff09;项目概述 在智能手机与移动互联网蓬勃发展的当下&#xff0c;移动设备已成为人们生活不可或缺的一部分&#xff0c;而电影购票这一日常娱乐消费行为也日益向移动端迁徙。鸿蒙系统作为新兴力量&…...

如何启动jar包隐藏cmd窗口

要启动一个JAR文件并隐藏命令行窗口&#xff08;cmd&#xff09;&#xff0c;你可以使用不同的方法&#xff0c;具体取决于你的操作系统。以下是几种常见的方法&#xff1a; 在Windows中使用批处理文件 你可以创建一个批处理文件&#xff08;.bat文件&#xff09;&#xff0c;…...

【Redis】基础3:一些应用场景

文章目录 1. session管理1.1 手机号登录流程1.2 session的数据结构设计1.2.1 一些概念1.2.2 session数据结构例子 1.3 引入redis来实现共享session1.3.1 流程发送验证码短信的流程验证码登录流程登录检查流程 1.3.2 要考虑的问题 2. 限时抢购代金券2.1 业务流程2.2 代金券表设计…...

【创新实训个人博客】multi-agent调研(2)

下面的部分我们将简单介绍现有的三个multi-agent框架&#xff0c;并对它们进行简单的比较 multi-agent框架分析 MetaGPT 相关资料 代码repo&#xff1a;https://github.com/geekan/MetaGPT论文&#xff1a;https://arxiv.org/pdf/2308.0035 AgentVerse 相关资料 代码repo&…...

对鸿蒙 Next 系统“成熟论”的深度剖析-优雅草卓伊凡

对鸿蒙 Next 系统“成熟论”的深度剖析-优雅草卓伊凡 在科技飞速发展的当下&#xff0c;鸿蒙 Next 系统无疑成为了众多科技爱好者与行业人士关注的焦点。今日&#xff0c;卓伊凡便收到这样一个饶有趣味的问题&#xff1a;鸿蒙 Next 系统究竟需要多长时间才能完全成熟&#xff…...

模方ModelFun瓦片数据操作教程

摘要&#xff1a;本文主要介绍模方ModelFun瓦片数据操作&#xff0c;包含&#xff1a;打开/关闭瓦片数据&#xff0c;备份和恢复&#xff0c;导出 OBJ/ OSGB&#xff0c;导出DOM/DSM。 1.打开/关闭瓦片数据 在“总体模型视图/OSGB”里对 tiles 进行操作&#xff1a;选择&…...

RabbitMQ应用(基于腾讯云)

1.防火墙配置 关于RabbitMQ的远程&#xff0c;主要有4个端口需要开通【入站规则】&#xff0c;分别是&#xff1a; 端口 5672&#xff1a;这是 RabbitMQ 的默认 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;端口&#xff0c;用于客户端与 RabbitMQ 服务器之…...

堆和二叉树的概念和操作

目录 1.树的概念 1.1数的表示 1.2二叉树 1.3特殊的二叉树 1.3.1满二叉树 1.3.2完全二叉树 1.3.3 二叉树存储结构 2.堆 2.1堆的实现 初始化和销毁 堆的插入 堆的向上调整算法​编辑 ​编辑 堆的删除 出堆顶 1.树的概念 树是非线性的数据结构&#xff0c;有限节点具有的层…...

互联网大厂Java面试实录:从Spring Boot到微服务架构的技术问答

互联网大厂Java面试实录&#xff1a;从Spring Boot到微服务架构的技术问答 在某互联网大厂的面试现场&#xff0c;严肃的面试官开始了对求职者谢飞机的技术考核。此次面试围绕Java技术栈的应用与场景展开。 第一轮&#xff1a;基础架构与语言 面试官&#xff1a; 请你用简单…...

Rollup、Webpack、Esbuild 和 Vite 前端打包工具

Rollup、Webpack、Esbuild 和 Vite 都是前端开发中常用的打包工具&#xff0c;它们各有特点&#xff0c;以下是对它们的详细对比&#xff1a; 核心功能 Rollup&#xff1a;专注于 JavaScript 模块打包&#xff0c;擅长将小的 JavaScript 模块打包成一个或多个文件&#xff0c…...

刀客独家 | 潘胜接管百度移动生态市场部

一、 据刀客doc向独家信源确认&#xff0c;百度移动生态事业群&#xff08;MEG&#xff09;市场部日前完成重要人事调整&#xff1a;潘胜已经接任市场负责人。 此前&#xff0c;根据雷锋网3月底的报道&#xff0c;百度云渠道生态总经理陈之若离职&#xff0c;原移动生态事业群…...

如何在Chrome浏览器中启用硬件加速【提升浏览器性能】

在使用谷歌浏览器时&#xff0c;硬件加速是提升性能的一个重要功能。它可以将一些计算任务从CPU转移到GPU&#xff0c;从而加速图像处理、视频播放等任务。如果您希望提升浏览器的运行速度&#xff0c;可以通过以下简单步骤启用硬件加速。 1. 打开Chrome浏览器设置 首先&#…...

部署mongodb三幅本集群

背景&#xff1a;原先使用的mongodb采用的是SSPL协议&#xff0c;此协议客户检测到有bug&#xff0c;故需要替换mongodb的版本&#xff0c;原先采用helm部署的mongodb但是无法找到4.1.4版本的chart包&#xff0c;故手写yaml部署 1、部署mongodb-arbiter服务 这个服务是用来选…...

JavaScript 解构赋值(下):对象解构与高级应用

对象解构赋值 基本语法 const person { name: Alice, age: 30 }; const { name, age } person;console.log(name); // Alice console.log(age); // 30别名 const { name: fullName, age: years } person; console.log(fullName); // Alice console.log(years); // 30…...

批量级负载均衡(Batch-Wise Load Balance)和顺序级负载均衡(Sequence-Wise Load Balance)

本文主要比较了批量级负载均衡(Batch-Wise Load Balance)和顺序级负载均衡(Sequence-Wise Load Balance)在 Mixture-of-Experts(MoE)模型训练中的核心区别 。批量级负载均衡通过对整个训练批次的专家负载进行平衡约束,实现了更灵活的均衡策略,有助于专家在不同领域的专…...

什么是EI期刊?EI目录列表如何看?一文查看最新目录+避坑指南

近期有很多人在后台问小编关于EI期刊的各种问题&#xff0c;且前段时间EI期刊目录刚刚更新&#xff0c;小编正好借此&#xff0c;这期仔细给大家介绍一下。 什么是EI期刊&#xff1f; EI期刊也称为工程索引期刊&#xff0c;是供查阅工程技术领域文献的综合性情报检索刊物。每年…...

[创业之路-341]:华为人力资源管理 - 华为技术专家体系详解

华为技术专家体系详解 一、技术专家等级划分 华为技术专家体系以 “专业能力管理贡献” 为双维度&#xff0c;覆盖 19级&#xff08;技术专家B&#xff09;至22级&#xff08;集团核心领导者&#xff09;&#xff0c;其中 19B-20A级 为核心技术专家层级&#xff1a; 19B级&a…...

【HarmonyOS 5】鸿蒙检测系统完整性

【HarmonyOS 5】鸿蒙检测系统完整性 一、前言 从现实安全威胁来看&#xff0c;设备系统完整性风险已影响至移动应用的各个场景。不少用户因使用越狱设备&#xff08;Jailbreak&#xff09;或非真实设备&#xff08;Emulator&#xff09;&#xff0c;导致应用安全防护机制失效…...