基于 Elasticsearch 8.12.0 集群创建索引
索引创建
创建一个产品的索引
解释:
productId: 产品的唯一标识符,使用 keyword 类型,适合精确匹配和聚合操作。name: 产品名称,使用 text 类型进行全文搜索,同时包含一个 keyword 子字段用于精确匹配。description: 产品描述,使用 text 类型进行全文搜索。price: 产品价格,使用 float 类型。category: 产品类别,使用 keyword 类型,适合精确匹配和聚合操作。brand: 产品品牌,使用 keyword 类型。inStock: 产品库存状态,使用 boolean 类型。tags: 产品标签,使用 keyword 类型,适合精确匹配和聚合操作。createdAt 和 updated_at: 产品的创建和更新时间,使用 date 类型,支持多种日期格式。attributes: 产品的属性,使用 nested 类型,允许存储键值对形式的属性。curl --location --request PUT 'http://127.0.0.1:9200/product_data_index' \
--data '{"settings": {"number_of_shards": 5,"number_of_replicas": 1},"mappings": {"properties": {"productId": {"type": "keyword"},"name": {"type": "text","fields": {"keyword": {"type": "keyword","ignore_above": 256}}},"description": {"type": "text"},"price": {"type": "float"},"category": {"type": "keyword"},"brand": {"type": "keyword"},"inStock": {"type": "boolean"},"tags": {"type": "keyword"},"createdAt": {"type": "date","format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"},"updatedAt": {"type": "date","format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"},"attributes": {"type": "nested","properties": {"key": {"type": "keyword"},"value": {"type": "text"}}}}}
}'
KIbana新增测试数据
POST /product_data_index/_bulk
{"index": {"_index": "product_data_index"}}
{"productId": "P001", "name": "华为手机", "description": "高性能5G手机,搭载麒麟芯片,支持超快充电。", "price": 3999.0, "category": "电子产品", "brand": "华为", "inStock": true, "tags": ["手机", "5G", "华为"], "createdAt": "2025-03-18 10:00:00", "updatedAt": "2025-03-18 10:00:00", "attributes": [{"key": "颜色", "value": "黑色"}, {"key": "内存", "value": "8GB"}]}
{"index": {"_index": "product_data_index"}}
{"productId": "P002", "name": "小米电视", "description": "4K高清智能电视,支持多种流媒体应用。", "price": 2999.0, "category": "家电", "brand": "小米", "inStock": true, "tags": ["电视", "4K", "小米"], "createdAt": "2025-03-18 11:00:00", "updatedAt": "2025-03-18 11:00:00", "attributes": [{"key": "尺寸", "value": "55英寸"}, {"key": "分辨率", "value": "4K"}]}
{"index": {"_index": "product_data_index"}}
{"productId": "P003", "name": "苹果笔记本电脑", "description": "轻薄便携,搭载苹果M1芯片,性能强劲。", "price": 9999.0, "category": "电子产品", "brand": "苹果", "inStock": false, "tags": ["笔记本电脑", "苹果", "M1芯片"], "createdAt": "2025-03-18 12:00:00", "updatedAt": "2025-03-18 12:00:00", "attributes": [{"key": "内存", "value": "16GB"}, {"key": "存储", "value": "512GB SSD"}]}
{"index": {"_index": "product_data_index"}}
{"productId": "P004", "name": "联想台式电脑", "description": "高性能办公电脑,适合多任务处理。", "price": 5999.0, "category": "电子产品", "brand": "联想", "inStock": true, "tags": ["台式电脑", "联想", "办公"], "createdAt": "2025-03-18 13:00:00", "updatedAt": "2025-03-18 13:00:00", "attributes": [{"key": "处理器", "value": "Intel Core i7"}, {"key": "显卡", "value": "NVIDIA GeForce"}]}
{"index": {"_index": "product_data_index"}}
{"productId": "P005", "name": "美的空调", "description": "智能变频空调,节能高效,适合家庭使用。", "price": 3499.0, "category": "家电", "brand": "美的", "inStock": true, "tags": ["空调", "美的", "变频"], "createdAt": "2025-03-18 14:00:00", "updatedAt": "2025-03-18 14:00:00", "attributes": [{"key": "制冷量", "value": "1.5匹"}, {"key": "功能", "value": "冷暖两用"}]}
对应实体
import lombok.Data;import java.util.List;
import java.util.Map;/*** 功能描述** @author jason*/
@Data
public class EsProduct {/*** 商品唯一ID(如:P001)*/private String productId;/*** 商品名称(如:华为手机)*/private String name;/*** 商品详细描述* 示例:高性能5G手机,搭载麒麟芯片,支持超快充电。*/private String description;/*** 商品价格(单位:元)* 示例:3999.00*/private double price;/*** 商品分类* 示例:电子产品*/private String category;/*** 品牌名称* 示例:华为*/private String brand;/*** 库存状态* true-有货,false-无货*/private boolean inStock;/*** 商品标签列表* 示例:["手机", "5G", "华为"]*/private List<String> tags;/*** 创建时间(格式:yyyy-MM-dd HH:mm:ss)* 示例:2025-03-18 10:00:00*/private String createdAt;/*** 最后更新时间(格式:yyyy-MM-dd HH:mm:ss)* 示例:2025-03-18 10:00:00*/private String updatedAt;/*** 商品属性(JSON字符串格式)* 示例:[{"key":"颜色","value":"黑色"},{"key":"内存","value":"8GB"}]*/private List<Map<String, String>> attributes;}
脚本批量创建测试数据
package org.example.es;import org.example.es.entity.EsProduct;import java.text.SimpleDateFormat;
import java.util.*;/*** 测试数据生产类*/
public class TestDataGenerator {private static final Random random = new Random();private static final SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");// 预定义的品牌和分类private static final String[] BRANDS = {"华为", "小米", "苹果", "三星", "OPPO", "vivo", "荣耀", "一加", "realme", "iQOO"};private static final String[] CATEGORIES = {"智能手机", "笔记本电脑", "平板电脑", "智能手表", "耳机", "智能家居", "数码配件"};// 手机型号后缀private static final String[] PHONE_MODELS = {"Pro", "Plus", "Max", "Lite", "SE", "Ultra", "X", "Z"};// 颜色选项private static final String[] COLORS = {"黑色", "白色", "蓝色", "红色", "绿色", "紫色", "银色", "金色"};// 内存选项private static final String[] MEMORIES = {"4GB", "6GB", "8GB", "12GB", "16GB"};// 存储选项private static final String[] STORAGES = {"64GB", "128GB", "256GB", "512GB", "1TB"};/*** 获取产品测试数据* <p>* size 条数*/public static List<EsProduct> getTestEsProductList(int size) {List<EsProduct> esProductList = new ArrayList<>();for (int i = 0; i < size; i++) {EsProduct product = new EsProduct();// 生成产品IDproduct.setProductId("P" + String.format("%05d", i + 1));// 生成产品名称String brand = BRANDS[random.nextInt(BRANDS.length)];String model = random.nextInt(20) + "";String modelSuffix = PHONE_MODELS[random.nextInt(PHONE_MODELS.length)];product.setName(brand + " " + model + modelSuffix);// 生成描述product.setDescription(generateDescription(brand, product.getName()));// 生成价格 (500-15000之间的随机值,以99或00结尾)int basePrice = 500 + random.nextInt(14500);int priceEnding = random.nextBoolean() ? 99 : 00;product.setPrice(basePrice - (basePrice % 100) + priceEnding);// 设置分类product.setCategory(CATEGORIES[random.nextInt(CATEGORIES.length)]);// 设置品牌product.setBrand(brand);// 库存状态 (80%概率有货)product.setInStock(random.nextDouble() < 0.8);// 生成标签product.setTags(generateTags(brand, product.getCategory()));// 生成创建和更新时间 (过去365天内随机时间)Date now = new Date();Date randomDate = new Date(now.getTime() - (long) (random.nextDouble() * 365 * 24 * 60 * 60 * 1000));product.setCreatedAt(dateFormat.format(randomDate));// 更新时间比创建时间晚1-30天Date updateDate = new Date(randomDate.getTime() + (long) (1 + random.nextInt(30)) * 24 * 60 * 60 * 1000);product.setUpdatedAt(dateFormat.format(updateDate));// 生成属性product.setAttributes(generateAttributes());esProductList.add(product);}return esProductList;}private static String generateDescription(String brand, String name) {String[] features = {"高性能处理器", "超长续航", "高清显示屏", "快速充电", "多摄像头系统","5G网络支持", "大容量电池", "轻薄设计", "防水防尘", "高刷新率屏幕"};// 随机选择3-5个特性Collections.shuffle(Arrays.asList(features));int featureCount = 3 + random.nextInt(3);StringBuilder desc = new StringBuilder(brand + " " + name + ",");for (int i = 0; i < featureCount; i++) {desc.append(features[i]);if (i < featureCount - 1) {desc.append(",");}}desc.append("。");return desc.toString();}private static List<String> generateTags(String brand, String category) {List<String> tags = new ArrayList<>();tags.add(brand);tags.add(category);// 添加一些通用标签String[] commonTags = {"新品", "热销", "旗舰", "性价比", "2025新款"};if (random.nextBoolean()) {tags.add(commonTags[random.nextInt(commonTags.length)]);}// 如果是手机,添加5G标签if (category.contains("手机") && random.nextDouble() > 0.3) {tags.add("5G");}return tags;}private static List<Map<String, String>> generateAttributes() {List<Map<String, String>> attributes = new ArrayList<>();// 颜色属性Map<String, String> colorAttr = new HashMap<>();colorAttr.put("key", "颜色");colorAttr.put("value", COLORS[random.nextInt(COLORS.length)]);attributes.add(colorAttr);// 内存属性if (random.nextDouble() > 0.2) { // 80%概率有内存属性Map<String, String> memoryAttr = new HashMap<>();memoryAttr.put("key", "内存");memoryAttr.put("value", MEMORIES[random.nextInt(MEMORIES.length)]);attributes.add(memoryAttr);}// 存储属性if (random.nextDouble() > 0.2) { // 80%概率有存储属性Map<String, String> storageAttr = new HashMap<>();storageAttr.put("key", "存储");storageAttr.put("value", STORAGES[random.nextInt(STORAGES.length)]);attributes.add(storageAttr);}return attributes;}}
批量创建文档 2w 笔
@Testvoid bulkCreateDocument() {List<EsProduct> esProductList = TestDataGenerator.getTestEsProductList(20000);BulkResponse result = esClient.bulkCreateDocument("product_data_index", esProductList);if (result.errors()) {// 至少有一个操作失败for (BulkResponseItem item : result.items()) {if (item.error() != null) {log.info("批量插入数据,部分失败:{}", item.error().reason());}}} else {// 所有操作成功log.info("批量插入数据成功");}}
查询数据
相关文章:
基于 Elasticsearch 8.12.0 集群创建索引
索引创建 创建一个产品的索引 解释: productId: 产品的唯一标识符,使用 keyword 类型,适合精确匹配和聚合操作。name: 产品名称,使用 text 类型进行全文搜索,同时包含一个 keyword 子字段用于精确匹配。description:…...
LeetCode283.移动零
给定一个数组 arr,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2 输入: nums [0] 输出: [0…...
select、poll、epoll实现多路复用IO并对比差异
目录 一、select实现多路复用 1.select函数介绍 2.select优缺点 3.select使用示例 二、poll实现多路复用 1.poll函数介绍 2.poll优缺点 3.poll使用示例 三、epoll实现多路复用 1.epoll函数介绍 2.epoll工作原理 3.epoll工作模式 (1)水平触发LT模式 (2)边缘触发ET模…...
FastAPI-MCP
介绍 开源地址: https://github.com/tadata-org/fastapi_mcp FastAPI-MCP 是一个开源项目,旨在简化 FastAPI 应用与现代 AI 代理(如基于大语言模型的系统)之间的集成。它通过自动将 FastAPI 的所有 API 端点暴露为符合 Model Co…...
Matlab 复合模糊PID
1、内容简介 Matlab 209-复合模糊PID 可以交流、咨询、答疑 2、内容说明 略摘 要:在并联型模糊 PID 复合控制器设计中,必须根据偏差大小及时地调整模糊控制部分和 PID 控制 部分的比例,而这种较为复杂的控制策略利用普通的 Simulink 模块是很难实现的.采用S-函数来解决 这个问…...
javaSE.队列
链表:屁股入队,头部出队 链尾入队👇 是while(tail.next!null) 👇 链首出队(head.next)👇 仅获取队首👇...
c++基础·左值右值
一、左值与右值的本质特征 1. 基础定义 左值 (lvalue) ✅ 可出现在赋值运算符左侧 ✅ 可被取地址(有明确存储位置) ✅ 通常为具名变量(如int a 10;中的a) 右值 (rvalue) ❌ 不可出现在赋值左侧 ❌ 不可取地址(无持久…...
From RAG to Memory: Non-Parametric Continual Learning for Large Language Models
从RAG到记忆:大语言模型的无参数持续学习 原文链接:https://arxiv.org/pdf/2502.14802 Code: https://github.com/OSU-NLP-Group/HippoRAG 🧠 HippoRAG 2 流程概述 1. 离线索引(Offline Indexing) 在此阶段,HippoRAG 2 构建一个开放式知识图谱(Open KG)以存储知识…...
STM32配置系统时钟
1、STM32配置系统时钟的步骤 1、系统时钟配置步骤 先配置系统时钟,后面的总线才能使用时钟频率 2、外设时钟使能和失能 STM32为了低功耗,一开始是关闭了所有的外设的时钟,所以外设想要工作,首先就要打开时钟,所以后面…...
Docker 安装配置教程(配置国内源)
## 一、Windows 安装 Docker Desktop 1. 系统要求: - Windows 10 64位:专业版、企业版或教育版 - 必须开启 Hyper-V 和容器功能 - 至少 4GB 内存 2. 安装步骤: - 访问 Docker 官网下载 Docker Desktop - 双击安装程序 - 按照向导完成安装 - 重启电脑 ## 二、macOS 安装 Dock…...
016-C语言内存函数
C语言内存函数 文章目录 C语言内存函数1. memcpy2. memmove3. memset4. memcmp 注意: 使用这些函数需要包含 string.h头文件。 1. memcpy void * memcpy ( void * destination, const void * source, size_t num );从source指向的位置开始,向后复制num…...
[FPGA]设计一个DDS信号发生器
一、DDS DDS(Data Distribution Service) 是一种面向实时分布式系统的通信中间件标准,专为高性能、高可靠性、低延迟的数据传输场景设计。它由对象管理组织(OMG) 制定并维护,广泛应用于物联网(…...
MySQL 线上大表 DDL 如何避免锁表(pt-online-schema-change)
文章目录 1、锁表问题2、pt-online-schema-change 原理3、pt-online-schema-change 实战3.1、准备数据3.2、安装工具3.3、模拟锁表3.4、解决锁表 1、锁表问题 在系统研发过程中,随着业务需求千变万化,避免不了调整线上MySQL DDL数据表的操作,…...
脚本中**通配符用法解析
在文件路径匹配中,** 是一种特殊的通配符(Glob Pattern),主要用于表示递归匹配任意层级的子目录。这种语法常见于以下场景: 1. 典型应用场景 .gitignore 文件: **/__pycache__ 表示匹配项目根目录下所有层…...
5 提示词工程指南-计划与行动
5 提示词工程指南-计划与行动 计划与行动 Cline 有两种模式: Plan 描述目标和需求、提问与回答、讨论、抽象项目的各个方面、确定技术路线、确定计划 计划与确认相当于架构师,不编写代码Act 按计划编写代码 按照计划编码Plan 模式的本质是构建实际编码前的上下文,Act 的本…...
62页华为IPD-MM流程:市场调研理论与实践方案精读【附全文阅读】
本文围绕市场调研展开,介绍其是联系市场和企业的纽带,具有收集陈述事实、解释信息、预测市场变化的作用,在 IPD 产品开发流程各阶段有不同应用。市场调研类型包括定性和定量研究,一般程序涵盖定义问题、拟定计划、抽样设计等多个环节。常用调研方法多样,各有特点和适用项目…...
(一)mac中Grafana监控Linux上的CPU等(Node_exporter 安装使用)
机器状态监控(监控服务器CPU,硬盘,网络等状态) Node_exporter安装在被测服务器上,启动服务 各步骤的IP地址要换为被测服务器的IP地址Prometheus.yml的 targets值网页访问的ip部分grafana添加数据源的URL 注意:只需要在被监听的服务器安装 n…...
STM32单片机入门学习——第44节: [13-1] PWR电源控制
写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.04.20 STM32开发板学习——第44节: [13-1] PWR电源控制 前言开发板说明引用解答和科普一…...
Windows 10 上安装 Spring Boot CLI详细步骤
在 Windows 10 上安装 Spring Boot CLI 可以通过以下几种方式完成。以下是详细的步骤说明: 1. 手动安装(推荐) 步骤 1:下载 Spring Boot CLI 访问 Spring Boot CLI 官方发布页面。下载最新版本的 .zip 文件(例如 sp…...
WEMOS LOLIN32 开发板引脚布局和技术规格
🔗 快速链接ESP32 Development Boards, Sensors, Tools, Projects and More https://megma.ma/wp-content/uploads/2021/08/Wemos-ESP32-Lolin32-Board-BOOK-ENGLISH.pdf WEMOS LOLIN32 Development Board Details, Pinout, Specs WEMOS LOLIN32 Development Board …...
【AI 加持下的 Python 编程实战 2_07】第七章:基于 Copilot 完整演示问题分解能力在实际问题中的落地应用
【全新第二版《Learn AI-assisted Python Programming》封面】 写在前面 问题分解能力在 AI 辅助编程中具有举足轻重的作用。但是怎样分解才算合理有效呢?本章从一个具体的案例切入,完整展示了 GitHub Copilot 在自顶而下设计论的指导下圆满完成既定任务…...
React 路由入门秘籍:BrowserRouter 的江湖之道
前言 各位江湖中人,今日咱们聊一门流传在前端江湖的神秘绝学:<BrowserRouter>。此技出自 React 路由门派,专修客户端路由之道,擅长在 Web 世界中轻功跳转、闪转腾挪,悄无声息间掌控页面切换。 若你是构建现代 Web 应用的侠客,这篇秘籍堪比九阳真经,一经参悟,便…...
软件安装,systemctl命令,软连接
yum是centos里面的(apt是Ubuntu的) yum:RPM软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题 语法:yum 【-y】【install | remove | search | restart 】软件名称 -y:自动确…...
SpringBoot Actuator健康检查:自定义HealthIndicator
文章目录 引言一、Spring Boot Actuator健康检查概述二、自定义HealthIndicator的必要性三、实现自定义HealthIndicator四、高级健康检查配置五、实现自定义健康状态和响应码总结 引言 Spring Boot Actuator是Spring Boot框架中用于监控和管理应用程序的强大功能模块。它提供了…...
注意力机制(np计算示例)单头和多头
为了更好理解注意力机制里面的qkv矩阵,使用np来演示。 单头注意力 import numpy as np import math# 初始化输入 X X np.array([[[1, 2, 3], [4, 5, 6]]])# 初始化权重矩阵 WQ、WK、WV WQ np.array([[1, 0], [0, 1], [0, 0]])WK np.array([[1, 0], [0, 1], [0,…...
生成对抗网络(Generative adversarial network——GAN)
文章目录 1. 前言1.1 判别器和生成器的作用?2.2 个人总结 2. 核心代码示例2.1 训练判别器网络2.2 训练生成器网络 参考文章 1. 前言 生成对抗网络的原文:Generative Adversarial Nets,该论文的精读视频:生成对抗网络GAN开山之作论…...
CSGHub开源版本v1.6.0更新
CSGHub v1.6.0 带来了多项核心功能升级与性能优化,显著增强了对大模型推理、微调、评估等流程的支持,并进一步完善了推理服务与用户交互体验。 插件化推理与训练引擎框架 推理、微调和评估引擎现已全面模块化,支持通过配置文件灵活接入多种引…...
Redis日常学习(一)
我的Redis学习笔记:从命令行到性能调优 Redis Redis(Remote Dictionary Server)本质上是一个基于内存的键值存储系统. 安装配置Redis的过程非常简单: # Ubuntu/Debian安装Redis sudo apt-get update sudo apt-get install red…...
Unity3D仿星露谷物语开发37之浇水动画
1、目标 当点击水壶时,实现浇水的动画。同时有一个水从水壶中流出来的特效。 假如某个grid被浇过了,则不能再浇水了。。 如果某个grid没有被dug过,也不能被浇水。 2、优化Settings.cs脚本 增加如下内容: public static float…...
JavaScript 一维数组转不含零的两个数
问题描述: /*** param {number} n* return {number[]}*/ var getNoZeroIntegers function(n) {for(let i 1;i<n;i){if(String(i).indexOf(0) -1&&String(n-i).indexOf(0) -1){return [i,n-i]}}};String类型indexOf()函数如果找不到字串则返回-1&…...
抽象工厂模式及其在自动驾驶中的应用举例(c++代码实现)
模式定义 抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,用于封装一组具有共同主题的独立对象创建过程。该模式通过提供统一接口创建相关对象家族,而无需指定具体实现类,特别适合需要保证系统组件兼容…...
知乎十四载:从精英问答到AI时代的知识灯塔
一、起源:Quora 的火种与周源的执念 2010 年,互联网浪潮正汹涌澎湃,各种新兴平台如雨后春笋般不断涌现。就在这一年的一个夜晚,周源像往常一样在网上浏览着各类信息,当他打开美国问答网站 Quora 时,瞬间被…...
Linux文件时间戳详解:Access、Modify、Change时间的区别与作用
在 Linux 系统中,文件的这三个时间戳(Access、Modify、Change)分别表示不同的文件状态变更时间,具体含义如下: 1. Access Time (Access) 含义:文件最后一次被访问的时间(读取内容或执行…...
Doris + Iceberg 构建冷热分层数据湖架构:架构设计与实战指南
在海量数据治理与存储演进中,冷热数据分层 已成为降本增效的关键策略。本篇将深入探讨如何结合 Apache Doris 与 Apache Iceberg 构建一套高性能、可扩展的数据湖架构,支持冷热数据自动分层、快速查询与灵活扩展。 一、背景:为什么需要冷热数…...
顺序表和链表的区别(C语言)
前言 线性表是最基础的数据结构之一,其中顺序表与链表分别代表两种存储方式: 顺序表(Sequential List):底层用数组实现,要求内存连续,典型代码以 int data[N] 或动态分配的 malloc/realloc 数…...
【Redis】Redis中的常见数据类型(一)
文章目录 前言一、Redis前置知识1. 全局命令2、数据结构和内部编码3. 单线程架构 二、String 字符串1. 常见命令2. 计数命令3.其他命令4. 内部编码5. 典型使用场景 三、Hash哈希1. 命令2.内部编码3. 使用场景4. 缓存方式对比 结语 前言 Redis 提供了 5 种数据结构,…...
Vue3 + TypeScript,使用祖先传后代模式重构父传子模式
父传子模式 父组件 SampleInput.vue <script setup lang"ts" name"SampleInput"> import { ref } from "vue"; import type { ApplyBasicInfo, Apply, ApplySample } from "/interface"; import CommonApplySampleTable from …...
MySQL:9.表的内连和外连
9.表的内连和外连 表的连接分为内连和外连 9.1 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,之前查询都是内连 接,也是在开发过程中使用的最多的连接查询。 语法: select 字段 from 表1 inner join 表2 on 连接…...
(mac)Grafana监控系统之监控Linux的Redis
Grafana安装-CSDN博客 普罗米修斯Prometheus监控安装(mac)-CSDN博客 1.Redis_exporter安装 直接下载 wget https://github.com/oliver006/redis_exporter/releases/download/v1.0.3/redis_exporter-v1.0.3.linux-amd64.tar.gz 解压 tar -xvf redis_…...
Multisim使用教程详尽版--(2025最新版)
一、Multisim14前言 1.1、主流电路仿真软件 1. Multisim:NI开发的SPICE标准仿真工具,支持模拟/数字电路混合仿真,内置丰富的元件库和虚拟仪器(示波器、频谱仪等),适合教学和竞赛设计。官网:艾…...
python pdf转图片再OCR
先pdf转图片 import os from pdf2image import convert_from_path# PDF文件路径 pdf_path /Users/xxx/2022.pdf # 输出图片的文件夹 output_folder ./output_images2022 # 输出图片的命名格式 output_name page# 如果输出文件夹不存在,创建它 if not os.path.ex…...
npm link 使用指南
npm link 使用指南 npm link 是一个非常有用的命令,主要用于在开发过程中将本地 npm 包链接到全局 npm 目录,从而可以在其他项目中使用这个本地包,而不需要发布到 npm 仓库。 基本用法 1. 创建全局链接 进入你要链接的本地包的根目录&…...
免费图片软件,可矫正倾斜、调整去底效果
软件介绍 有个超棒的软件要给大家介绍一下哦,它就是——ImgTool,能实现图片漂白去底的功能,而且重点是,它是完全免费使用的呢,功能超强大! 软件特点及使用便捷性 这软件是绿色版本的哟,就像一…...
5G网络切片:精准分配资源,提升网络效率的关键技术
5G网络切片:精准分配资源,提升网络效率的关键技术 随着5G技术的广泛应用,网络切片(Network Slicing)作为其核心创新之一,正在改变传统网络架构。它通过将物理网络划分为多个逻辑网络(切片&…...
seate TCC模式案例
场景描述 用户下单时,需要创建订单并从用户账户中扣除相应的余额。如果订单创建成功但余额划扣失败,则需要回滚订单创建操作。使用 Seata 的 TCC 模式来保证分布式事务的一致性。 1. 项目结构 假设我们有两个微服务: Order Service&#x…...
Transfomer的本质
Transformer是一个基于自注意力机制的深度学习模型,用于处理序列数据,主要结构包括编码器和解码器,每个部分由多头自注意力和前馈网络组成,加上残差连接和层归一化,以及位置编码。它解决了RNN的并行处理问题࿰…...
final修饰变量的注意
在Java中,使用final修饰变量时,需注意以下关键事项: 1. 初始化规则 实例变量: 必须在声明时、构造器或实例初始化块中初始化。所有构造器分支必须保证初始化。 class Example {final int x; // 实例变量final int y;public Exampl…...
前端与传统接口的桥梁:JSONP解决方案
1.JSONP原理 1.1.动态脚本注入 说明:通过创建 <script> 标签绕过浏览器同源策略 1.2.回调约定 说明:服务端返回 函数名(JSON数据) 格式的JS代码 1.3.自动执行 说明:浏览器加载脚本后立即触发前端预定义的回调函数(现代开…...
SQL注入 01
0x01 用户、脚本、数据库之间的关系 首先客户端发出了ID36的请求,脚本引擎收到后将ID36的请求先代入脚本的sql查询语句Select * from A where id 36 , 然后将此代入到数据库中进行查询,查到后将返回查询到的所有记录给脚本引擎,接…...
Java之封装(学习笔记)
封装定义(个人理解:) 封装就像电视遥控器的按钮,比如音量键,对于我们使用者来说就是可以直接按下去调控音量,对于代码写作者来说就是封装了调控音量的方法,使得我们只能去调控,不能改…...