Go语言编写一个进销存Web软件的demo
Go语言编写一个进销存Web软件的demo
用户现在要求用。之前他们已经讨论了用Django实现的方案,现在突然切换到Go,可能有几个原因。首先,用户可能对Go语言感兴趣,或者他们公司的技术栈转向了Go。其次,用户可能希望比较不同语言实现的差异,或者需要更高性能的解决方案。
go和django的区别
接下来,我需要分析用户的具体需求。用户提到需要多个界面和权限管理,之前Django版本中已经涉及了这些内容,所以用户可能希望Go版本也能实现类似的功能,但用Go的特性来构建。同时,用户可能希望这个demo足够简单,但又能展示关键功能,比如库存管理、订单处理、用户权限等。
Gin是一个高性能的轻量级框架
我需要考虑Go语言常用的Web框架。Gin是一个高性能的轻量级框架,适合快速开发,所以选择Gin作为基础。数据库方面,使用SQLite作为嵌入式数据库,方便demo的部署和测试,不需要复杂的配置。
1.数据库模型
数据模型的设计需要与之前的Django模型对应,但结构体定义会有所不同。比如,Product结构体需要包含名称、库存、价格等字段。User结构体需要处理权限,可能使用角色(Role)字段来区分不同用户权限,如管理员、普通用户等。
2.权限管理
在Go中可以使用中间件来处理。比如,对于需要管理员权限的路由,添加一个中间件检查用户的角色是否为admin。登录认证可以使用JWT,生成token,然后在后续请求中验证token的有效性,并解析用户信息。
3.路由设计
需要区分公开路由(如登录)和需要认证的路由(如产品管理)。每个路由组可以应用不同的中间件,确保权限控制。
4.前端
用户可能希望有简单的HTML界面,所以使用Go的模板引擎来渲染页面。同时,提供RESTful API供前端调用,这样以后可以扩展为前后端分离的架构。
在实现具体功能时,比如创建采购订单,需要更新产品的库存。这里要注意事务处理,确保库存增减的原子性,避免并发问题。虽然demo可能不需要处理高并发,但良好的实践可以提升代码质量。
5.测试
需要确保各个接口的正常工作,比如添加产品、登录、创建订单等。使用curl命令或者Postman来测试API,同时检查数据库中的数据变化是否正确。
可能遇到的挑战包括Go与Django在ORM方面的差异。Go没有内置的ORM,所以需要使用database/sql库手动编写SQL语句,或者使用第三方库如gorm。但在demo中,为了简洁,可能直接使用SQLite的驱动和标准库操作数据库,这样减少依赖。
最后,需要提供清晰的步骤说明,包括如何安装依赖、运行程序、测试接口等。用户可能不熟悉Go的模块管理,所以需要指出使用go mod初始化项目,并获取必要的依赖包。
总结来说,用户需要一个用Go语言实现的简单进销存系统demo,具备基本的产品管理、订单处理、用户认证和权限控制功能。使用Gin框架和SQLite数据库,通过中间件和JWT实现权限管理,前端使用HTML模板渲染。需要确保代码结构清晰,易于理解和扩展。
一个使用Go语言(Gin框架)实现的简易进销存系统Demo
包含基础功能、权限控制和API接口:
main.go
package mainimport ("database/sql""fmt""log""net/http""os""time""github.com/gin-gonic/gin"_ "github.com/mattn/go-sqlite3""golang.org/x/crypto/bcrypt"
)// 数据结构定义
type Product struct {ID int `json:"id"`Name string `json:"name" binding:"required"`Stock int `json:"stock"`Price float64 `json:"price" binding:"required"`CreatedAt string `json:"created_at"`
}type User struct {ID int `json:"id"`Username string `json:"username" binding:"required"`Password string `json:"password" binding:"required"`Role string `json:"role"` // admin/user
}type Order struct {ID int `json:"id"`ProductID int `json:"product_id" binding:"required"`Quantity int `json:"quantity" binding:"required"`Type string `json:"type" binding:"required"` // purchase/saleTotalPrice float64 `json:"total_price"`CreatedAt string `json:"created_at"`
}// 数据库初始化
func initDB() *sql.DB {db, err := sql.Open("sqlite3", "./inventory.db")if err != nil {log.Fatal(err)}// 创建表sqlStmt := `CREATE TABLE IF NOT EXISTS products (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,stock INTEGER DEFAULT 0,price REAL NOT NULL,created_at DATETIME DEFAULT CURRENT_TIMESTAMP);CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT,username TEXT UNIQUE NOT NULL,password TEXT NOT NULL,role TEXT NOT NULL DEFAULT 'user');CREATE TABLE IF NOT EXISTS orders (id INTEGER PRIMARY KEY AUTOINCREMENT,product_id INTEGER NOT NULL,quantity INTEGER NOT NULL,type TEXT NOT NULL,total_price REAL NOT NULL,created_at DATETIME DEFAULT CURRENT_TIMESTAMP);`_, err = db.Exec(sqlStmt)if err != nil {log.Printf("%q: %s\n", err, sqlStmt)return nil}return db
}// 中间件
func AuthMiddleware() gin.HandlerFunc {return func(c *gin.Context) {token := c.GetHeader("Authorization")if token == "" {c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"error": "未授权访问"})return}claims, err := ParseToken(token)if err != nil {c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"error": "无效令牌"})return}c.Set("user", claims)c.Next()}
}func AdminMiddleware() gin.HandlerFunc {return func(c *gin.Context) {user, exists := c.Get("user")if !exists {c.AbortWithStatus(http.StatusUnauthorized)return}if user.(*UserClaims).Role != "admin" {c.AbortWithStatusJSON(http.StatusForbidden, gin.H{"error": "权限不足"})return}c.Next()}
}// 主函数
func main() {db := initDB()defer db.Close()r := gin.Default()// 公共路由public := r.Group("/api"){public.POST("/login", loginHandler(db))public.POST("/register", registerHandler(db))}// 需要认证的路由private := r.Group("/api")private.Use(AuthMiddleware()){// 产品管理private.GET("/products", getProductsHandler(db))private.POST("/products", AdminMiddleware(), createProductHandler(db))// 订单管理private.POST("/orders", createOrderHandler(db))private.GET("/orders", getOrdersHandler(db))}// 启动服务port := os.Getenv("PORT")if port == "" {port = "8080"}r.Run(":" + port)
}// 处理函数示例
func createProductHandler(db *sql.DB) gin.HandlerFunc {return func(c *gin.Context) {var product Productif err := c.ShouldBindJSON(&product); err != nil {c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})return}stmt, err := db.Prepare("INSERT INTO products(name, stock, price) VALUES(?, ?, ?)")if err != nil {c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}defer stmt.Close()result, err := stmt.Exec(product.Name, product.Stock, product.Price)if err != nil {c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}id, _ := result.LastInsertId()c.JSON(http.StatusCreated, gin.H{"id": id})}
}func createOrderHandler(db *sql.DB) gin.HandlerFunc {return func(c *gin.Context) {var order Orderif err := c.ShouldBindJSON(&order); err != nil {c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})return}// 开始事务tx, err := db.Begin()if err != nil {c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}// 检查产品库存var currentStock interr = tx.QueryRow("SELECT stock FROM products WHERE id = ?", order.ProductID).Scan(¤tStock)if err != nil {tx.Rollback()c.JSON(http.StatusNotFound, gin.H{"error": "产品不存在"})return}// 更新库存newStock := currentStockif order.Type == "purchase" {newStock += order.Quantity} else if order.Type == "sale" {if currentStock < order.Quantity {tx.Rollback()c.JSON(http.StatusBadRequest, gin.H{"error": "库存不足"})return}newStock -= order.Quantity}_, err = tx.Exec("UPDATE products SET stock = ? WHERE id = ?", newStock, order.ProductID)if err != nil {tx.Rollback()c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}// 创建订单stmt, err := tx.Prepare("INSERT INTO orders(product_id, quantity, type, total_price) VALUES(?, ?, ?, ?)")if err != nil {tx.Rollback()c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}defer stmt.Close()_, err = stmt.Exec(order.ProductID, order.Quantity, order.Type, order.TotalPrice)if err != nil {tx.Rollback()c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})return}tx.Commit()c.JSON(http.StatusCreated, gin.H{"message": "订单创建成功"})}
}// JWT相关功能(示例代码)
func GenerateToken(user *User) (string, error) {// 实现JWT生成逻辑return "sample_token", nil
}func ParseToken(tokenString string) (*UserClaims, error) {// 实现JWT解析逻辑return &UserClaims{Username: "admin", Role: "admin"}, nil
}type UserClaims struct {Username stringRole string
}
运行步骤
-
安装依赖:
go mod init inventory
go get github.com/gin-gonic/gin
go get github.com/mattn/go-sqlite3
go get golang.org/x/crypto/bcrypt
运行界面
D:\work\goproject>go mod init inventory
go: creating new go.mod: module inventory
go: to add module requirements and sums:go mod tidyD:\work\goproject>go get github.com/gin-gonic/gin
go: downloading github.com/gin-gonic/gin v1.10.0
go: downloading github.com/gin-contrib/sse v0.1.0
go: downloading github.com/mattn/go-isatty v0.0.20
go: downloading golang.org/x/net v0.25.0
go: downloading github.com/bytedance/sonic v1.11.6
go: downloading github.com/goccy/go-json v0.10.2
go: downloading github.com/json-iterator/go v1.1.12
go: downloading github.com/go-playground/validator/v10 v10.20.0
go: downloading github.com/pelletier/go-toml/v2 v2.2.2
go: downloading github.com/ugorji/go/codec v1.2.12
go: downloading google.golang.org/protobuf v1.34.1
go: downloading gopkg.in/yaml.v3 v3.0.1
go: downloading golang.org/x/sys v0.20.0
go: downloading golang.org/x/text v0.15.0
go: downloading github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd
go: downloading github.com/leodido/go-urn v1.4.0
go: downloading github.com/modern-go/reflect2 v1.0.2
go: downloading golang.org/x/crypto v0.23.0
go: downloading github.com/gabriel-vasile/mimetype v1.4.3
go: downloading github.com/go-playground/universal-translator v0.18.1
go: downloading github.com/go-playground/locales v0.14.1
下载完毕后会修改go.mod文件
module inventorygo 1.24.2require (github.com/bytedance/sonic v1.11.6 // indirectgithub.com/bytedance/sonic/loader v0.1.1 // indirectgithub.com/cloudwego/base64x v0.1.4 // indirectgithub.com/cloudwego/iasm v0.2.0 // indirectgithub.com/gabriel-vasile/mimetype v1.4.3 // indirectgithub.com/gin-contrib/sse v0.1.0 // indirectgithub.com/gin-gonic/gin v1.10.0 // indirectgithub.com/go-playground/locales v0.14.1 // indirectgithub.com/go-playground/universal-translator v0.18.1 // indirectgithub.com/go-playground/validator/v10 v10.20.0 // indirectgithub.com/goccy/go-json v0.10.2 // indirectgithub.com/json-iterator/go v1.1.12 // indirectgithub.com/klauspost/cpuid/v2 v2.2.7 // indirectgithub.com/leodido/go-urn v1.4.0 // indirectgithub.com/mattn/go-isatty v0.0.20 // indirectgithub.com/mattn/go-sqlite3 v1.14.27 // indirectgithub.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirectgithub.com/modern-go/reflect2 v1.0.2 // indirectgithub.com/pelletier/go-toml/v2 v2.2.2 // indirectgithub.com/twitchyliquid64/golang-asm v0.15.1 // indirectgithub.com/ugorji/go/codec v1.2.12 // indirectgolang.org/x/arch v0.8.0 // indirectgolang.org/x/crypto v0.37.0 // indirectgolang.org/x/net v0.25.0 // indirectgolang.org/x/sys v0.32.0 // indirectgolang.org/x/text v0.24.0 // indirectgoogle.golang.org/protobuf v1.34.1 // indirectgopkg.in/yaml.v3 v3.0.1 // indirect
)
运行代码
go run main.go
提示错误
.\main.go:129:25: undefined: loginHandler
.\main.go:130:28: undefined: registerHandler
.\main.go:138:28: undefined: getProductsHandler
.\main.go:143:26: undefined: getOrdersHandler
可以看出代码中没有上面4个函数,直接屏蔽掉就OK
再次运行
go run main.go
2025/04/10 22:16:58 "Binary was compiled with 'CGO_ENABLED=0', go-sqlite3 requires cgo to work. This is a stub":CREATE TABLE IF NOT EXISTS products (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,stock INTEGER DEFAULT 0,price REAL NOT NULL,created_at DATETIME DEFAULT CURRENT_TIMESTAMP);CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT,username TEXT UNIQUE NOT NULL,password TEXT NOT NULL,role TEXT NOT NULL DEFAULT 'user');CREATE TABLE IF NOT EXISTS orders (id INTEGER PRIMARY KEY AUTOINCREMENT,product_id INTEGER NOT NULL,quantity INTEGER NOT NULL,type TEXT NOT NULL,total_price REAL NOT NULL,created_at DATETIME DEFAULT CURRENT_TIMESTAMP);
[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production. - using env: export GIN_MODE=release- using code: gin.SetMode(gin.ReleaseMode)[GIN-debug] POST /api/products --> main.main.createProductHandler.func3 (5 handlers)
[GIN-debug] POST /api/orders --> main.main.createOrderHandler.func4 (4 handlers)
[GIN-debug] [WARNING] You trusted all proxies, this is NOT safe. We recommend you to set a value.
Please check https://pkg.go.dev/github.com/gin-gonic/gin#readme-don-t-trust-all-proxies for details.
[GIN-debug] Listening and serving HTTP on :8080
提升运行成功
功能说明
-
核心功能
-
产品管理(CRUD)
-
采购/销售订单管理
-
实时库存更新
-
用户认证(JWT)
-
角色权限控制(admin/user)
-
API接口示例
bash
复制
# 注册用户 curl -X POST http://localhost:8080/api/register \-H "Content-Type: application/json" \-d '{"username":"admin","password":"admin123","role":"admin"}'# 登录获取Token curl -X POST http://localhost:8080/api/login \-H "Content-Type: application/json" \-d '{"username":"admin","password":"admin123"}'# 创建产品(需要admin权限) curl -X POST http://localhost:8080/api/products \-H "Authorization: Bearer sample_token" \-H "Content-Type: application/json" \-d '{"name":"MacBook Pro", "stock":10, "price":1999.99}'# 创建采购订单 curl -X POST http://localhost:8080/api/orders \-H "Authorization: Bearer sample_token" \-H "Content-Type: application/json" \-d '{"product_id":1, "quantity":5, "type":"purchase", "total_price":9999.95}'
-
前端界面建议
html
复制
<!-- 示例产品列表界面 --> <!DOCTYPE html> <html> <head><title>产品管理</title><link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet"> </head> <body><div class="container mt-4"><h2>产品列表</h2><div id="product-list" class="row"></div></div><script>// 使用fetch API获取产品数据fetch('/api/products', {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}}).then(response => response.json()).then(data => {const container = document.getElementById('product-list');data.forEach(product => {const card = `<div class="col-md-4 mb-3"><div class="card"><div class="card-body"><h5 class="card-title">${product.name}</h5><p class="card-text">库存: ${product.stock}<br>价格: $${product.price}</p></div></div></div>`;container.innerHTML += card;});});</script> </body> </html>
运行 HTML
系统扩展建议
-
增强功能
-
添加供应商/客户管理
-
实现库存预警功能
-
增加报表统计模块
-
支持文件导入导出
-
添加操作日志记录
-
性能优化
-
添加Redis缓存层
-
实现数据库连接池
-
添加API限流中间件
-
支持集群部署
-
安全增强
-
实现HTTPS支持
-
添加请求参数校验
-
实现密码策略强制
-
添加IP白名单控制
-
部署方案
bash
复制
# 使用Docker部署 FROM golang:1.18-alpine WORKDIR /app COPY go.mod ./ COPY go.sum ./ RUN go mod download COPY *.go ./ RUN go build -o /inventory EXPOSE 8080 CMD [ "/inventory" ]
这个Demo实现了以下核心功能:
-
RESTful API设计
-
JWT身份验证
-
角色权限控制
-
库存事务管理
-
基础数据操作
-
错误处理机制
可以根据实际需求继续扩展以下功能:
-
增加Swagger API文档
-
实现单元测试
-
添加Prometheus监控
-
集成消息队列
-
实现分布式锁
-
添加数据验证规则
相关文章:
Go语言编写一个进销存Web软件的demo
Go语言编写一个进销存Web软件的demo 用户现在要求用。之前他们已经讨论了用Django实现的方案,现在突然切换到Go,可能有几个原因。首先,用户可能对Go语言感兴趣,或者他们公司的技术栈转向了Go。其次,用户可能希望比较不…...
架构设计之Redisson分布式锁-可重入同步锁(一)
架构设计之Redisson分布式锁-可重入同步锁(一) Redisson分布式锁官方博客地址 1、Redisson是什么 Redisson 是一个基于 Redis 的 Java 分布式工具库,它提供了 分布式锁、集合、队列、缓存、Map、限流、任务调度 等高级数据结构和功能,极大地简化了 Ja…...
使用libcurl编写爬虫程序指南
用户想知道用Curl库编写的爬虫程序是什么样的。首先,我需要明确Curl本身是一个命令行工具和库,用于传输数据,支持多种协议。而用户提到的“Curl库”可能指的是libcurl,这是一个客户端URL传输库,可以用在C、C等编程语言…...
【数据结构】排序算法(下篇·终结)·解析数据难点
前引:归并排序作为一种高效排序方法,掌握起来还是有点困难的,何况需要先接受递归的熏陶,这正是编程的浪漫之处,我们不断探索出新的可能,如果给你一串数据让其变得有序?是选择简单的冒泡、插入排…...
Django 使用 Celery 完成异步任务或定时任务
1 介绍 Celery是一个分布式任务队列,由三个主要组件组成:Celery worker、Celery beat 和消息代理(例如 Redis 或 RabbitMQ)。这些组件一起协作,让开发者能够轻松地执行异步任务和定时任务。 Celery worker࿱…...
Excel 自动执行全局宏
Excel 自动执行全局宏 25.04.09 步骤 1:创建个人宏工作簿(Personal.xlsb) 生成Personal.xlsb (如尚未存在): 打开Excel → 开发工具 → 录制宏 → 选择“保存到个人宏工作簿” → 停止录制。按 Alt F11 进…...
【前缀和】矩阵区域和(medium)
矩阵区域和(medium) 题⽬描述:解法:代码Java 算法代码:C 算法代码: 题⽬描述: 题⽬链接:1314. 矩阵区域和 给你⼀个 m x n 的矩阵 mat 和⼀个整数 k ,请你返回⼀个矩阵 …...
Android ViewStub显示VISIBLE与消失GONE,Kotlin
Android ViewStub显示VISIBLE与消失GONE,Kotlin import android.os.Bundle import android.util.Log import android.view.View import android.view.ViewStub import android.widget.Button import androidx.appcompat.app.AppCompatActivity import androidx.trac…...
【愚公系列】《高效使用DeepSeek》063-海关数据获取和管理
🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...
探索 OSPF 协议:构建高效网络的基石
文章目录 目录 文章目录 前言 一.OSPF协议概述 二.OSPF相关概念 🕤 2.1 基本思想 🕤 2.2 SPF算法 🕤 2.3 区域划分编辑 三.OSPF工作原理 编辑 🕤 3.1 DR/BDR选举 四.OSPF网络类型 🕤4.1 BMA 🕤4.2 P2P …...
深入剖析C++单例模式的八种实现演进与工程实践
深入剖析C单例模式的八种实现演进与工程实践 一、从基础到工业级:单例模式的演进图谱 1.1 基础实现的致命缺陷分析 // 初级版(非线程安全) class NaiveSingleton { public:static NaiveSingleton* getInstance() {if (!instance) {instanc…...
手游防DDoS攻击SDK接入
在手游中集成防DDoS攻击SDK是抵御流量型和应用层攻击的核心手段之一。以下从SDK选型、接入流程、防护策略优化三个维度提供完整指南,并附关键代码示例: 一、SDK选型与核心能力对比 服务商优势劣势适用场景…...
【C++进阶】关联容器:multimap类型
目录 一、multimap 基础概念与底层实现 1.1 定义与核心特性 1.2 底层数据结构 1.3 类模板定义 1.4 与其他容器的对比 二、multimap 核心操作详解 2.1 定义与初始化 2.2 插入元素 2.3 查找元素 2.4 删除元素 2.5 遍历元素 三、性能分析与适用场景 3.1 时间复杂度分…...
学习threejs,使用EffectComposer后期处理组合器(采用RenderPass、FilmPass渲染通道)
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.EffectComposer 后期…...
用Django和AJAX创建一个待办事项应用
用Django和AJAX创建一个待办事项应用 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 用Django和AJAX创建一个待办事项应用让我们创建一个简单的 Django 项目,其中包含不同类型的 A…...
【微调大模型】使用LLaMA-Factory进行监督微调 Qwen2.5
本文使用LLaMA-Factory进行监督微调 Qwen2.5。 此监督微调(SFT)脚本具有以下特点: 支持单GPU和多GPU训练;支持全参数调优,LoRA,Q-LoRA,Dora。 下面详细介绍一下该脚本的使用方法。 目录 安装…...
前端 react+ant design ,后端 springboot +mysql+redis 全栈项目零基础小白从服务器初始化开始部署上线超详细保姆级教程
哈喽小伙伴们,好久不见,我是小李,今天,来电干货,希望对大家有帮助。 去年12月底的时候心血来潮,正好赶上腾讯云在做活动,就买了一台服务器,说是后面打算上线一两个项目,体验体验云服务器究竟是怎么玩的。后来由于实习和“冬招”,实在忙不过来了,就放在文件夹吃灰了…...
[Windows] OfficeAI 助手 v0.3.20(长期免费,2025-03-18 本地支持WPS_Word联动)
OfficeAI助手,作为Microsoft Office与WPS的得力智能插件,集文档自动生成、内容精准校对与润色、公式智能推荐等多功能于一体。它凭借强大的数据分析能力,深度融入Office/WPS办公生态,一键简化复杂流程,让办公效率倍增&…...
3DGS之光栅化
光栅化(Rasterization)是计算机图形学中将连续的几何图形(如三角形、直线等)转换为离散像素的过程,最终在屏幕上形成图像。 一、光栅化的核心比喻 像画家在画布上作画 假设你是一个画家,要把一个3D立方体画…...
可发1区的超级创新思路(python 、MATLAB实现):基于SAM+Informer+2DCNN的功率预测模型
首先声明,该模型为原创!原创!原创!且该思路还未有成果发表,感兴趣的小伙伴可以借鉴! 目录 首先声明,该模型为原创!原创!原创!且该思路还未有成果发表,感兴趣的小伙伴可以借鉴! 一、模型背景与核心创新 二、模型组件详解 1. SAM时空注意力模块 原理说明 代码实…...
【Java面试系列】Spring Boot微服务架构下的分布式事务解决方案与性能优化详解 - 3-5年Java开发必备知识
【Java面试系列】Spring Boot微服务架构下的分布式事务解决方案与性能优化详解 - 3-5年Java开发必备知识 1. 引言 在当今的微服务架构中,分布式事务是一个不可避免的话题。随着业务复杂度的提升,如何保证跨服务的数据一致性成为开发者和架构师必须面对…...
【MATLAB第114期】基于MATLAB的SHAP可解释神经网络分类模型(敏感性分析方法)
【MATLAB第114期】基于MATLAB的SHAP可解释神经网络分类模型(敏感性分析方法) 引言 该文章实现了一个可解释的神经网络分类模型,使用BP神经网络(BPNN)来预测特征输出。该模型利用12个变量参数作为输入特征进行训练。为…...
WPS免费使用宏(安装VBA插件)
WPS提示要开会员才能使用宏,多次搜索发现其实可以直接安装VBA插件就行,Mark一下 插件下载地址: https://www.onlinedown.net/soft/10044362.htm ‘’’ WPS插件软件介绍 wps vba是一款wps office插件,安装wps vba 7.1就可以让of…...
让测试飞起来——DevOps中的自动化测试实践指南
让测试飞起来——DevOps中的自动化测试实践指南 近年来,DevOps理念已经成为现代软件开发和运维的“最佳拍档”。它倡导“开发”和“运维”的协作,核心目标是加速交付,同时保障软件质量。而在这一过程中,测试自动化扮演了不可替代的角色。今天,我们就一起来聊聊测试自动化…...
开源AI大模型AI智能名片S2B2C商城小程序:科技浪潮下的商业新引擎
摘要: 本文聚焦于科技迅猛发展背景下,开源AI大模型、AI智能名片与S2B2C商城小程序的融合应用。通过分析元宇宙、人工智能、区块链、5G等前沿科技带来的商业变革,阐述开源AI大模型AI智能名片S2B2C商城小程序在整合资源、优化服务、提升用户体验…...
webpack配置导致浏览器自动刷新
文章目录 关键配置 - liveReload 关键配置 - liveReload const dev_config {devtool: source-map,// watch: true,devServer: {contentBase: path.resolve(__dirname, bin),port: 8005,host:192.168.xx.xx,inline: true,hot: false,liveReload: false //关键这一行【false不会…...
OPEX baota 2024.02.26
OPEX baota 2024.02.26 运维集成软件宝塔2024.02.26作废例子: 最重要的两个地方:上传文件 网站,重启应用服务器(tomcat) 其他很少用的...
【Pandas】pandas DataFrame to_numpy
Pandas2.2 DataFrame Conversion 方法描述DataFrame.astype(dtype[, copy, errors])用于将 DataFrame 中的数据转换为指定的数据类型DataFrame.convert_dtypes([infer_objects, …])用于将 DataFrame 中的数据类型转换为更合适的类型DataFrame.infer_objects([copy])用于尝试…...
Tensorflow2实现: LSTM-火灾温度预测
- **🍨 本文为[🔗365天深度学习训练营](https://mp.weixin.qq.com/s/rnFa-IeY93EpjVu0yzzjkw) 中的学习记录博客** - **🍖 原作者:[K同学啊](https://mtyjkh.blog.csdn.net/)** 一:理论知识基础 1.LSTM原理 一句话介…...
【降尺度】AI+CMIP6数据分析与可视化、降尺度技术与气候变化的区域影响、极端气候分析
气候变化已成为全球性挑战,对农业、生态系统、水资源、人类健康和社会经济系统产生深远影响。科学研究表明,自工业革命以来,人类活动导致的温室气体排放与全球气温上升、极端天气事件增加、冰川融化和海平面上升等现象密切相关。为科学理解和…...
粒子系统优化完成
按计划对幻世(OurDream)2D图形引擎的粒子系统进行了加强和优化,重点强化了粒子运动的控制和颜色混合效果的功能,目前优化过后的粒子系统的整体效果是令人满意的。...
spark-core编程
RDD转换算子 RDD 的两种算子:转换算子和行动算子。 RDD 根据数据处理方式的不同将算子整体上分为 Value 类型、双 Value 类型和 Key-Value 类型。 算子实际上是一些函数,用于数据处理。 Value类型 map 将处理的数据逐条进行映射转换,…...
智慧班牌系统解决方案,SaaS智慧电子班牌云平台
智慧班牌系统解决方案 系统概述 智慧班牌是智慧校园建设不断发展的产物,是教育信息化改革的载体。通过智慧班牌可以高效便捷传递各种知识信息和通知信息、及时反馈课堂信息、实现班级的透明化管理。智慧班牌将学生平安考勤、异常出勤情况及时反馈至家长、老师&…...
Flutter 2025 Roadmap
2025 这个路线图是有抱负的。它主要代表了我们这些在谷歌工作的人收集的内容。到目前为止,非Google贡献者的数量超过了谷歌雇佣的贡献者,所以这并不是一个详尽的列表,列出了我们希望今年Flutter能够出现的所有令人兴奋的新事物!在…...
【开发工具】科研开发中的主流AI工具整理及如何使用GPT润色英文论文
一、主流AI工具 AI技术发展至今已经逐渐成熟,并可以取代一部分科研和开发中的简单工作,并为复杂工作提高辅助,除此之外也是更高级的信息检索工具。熟练掌握 AI 工具在当前市场理应具有竞争优势,目前笔者在科研和开发中接触过AI工…...
用excel做九乘九乘法表
公式: IF($A2>B 1 , 1, 1,A2 & “" & B$1 & “” & $A2B$1,”")...
nacos配置达梦数据库驱动源代码步骤
1.在父工程pom.xml添加依赖: <dependency><groupId>com.dameng</groupId><artifactId>DmJdbcDriver18</artifactId><version>8.1.1.193</version> </dependency> 2.在nacos-config模块pom.xml添加依赖࿱…...
Spring Boot 线程池配置详解
Spring Boot 线程池配置详解 一、核心配置参数及作用 基础参数核心线程数 (corePoolSize) 作用:线程池中始终保持存活的线程数量,即使空闲也不回收。 建议:根据任务类型设定(如 I/O 密集型任务可设为 CPU 核心数 2)。 最大线程数 (maxPoolSize) 作用:…...
如何使用 qrcode.react生成二维码
qrcode.react(查看官网) 是一个用于 React 应用的 QR 码生成组件。下面是如何使用它的详细指南: 1、安装 npm install qrcode.react # 或者 yarn add qrcode.react2、基本用法 import {QRCodeSVG} from qrcode.react;const myPage () >…...
用VScode来编写前后端——构建基础框架
前言 我写这一个板块的原因是我参加了我们学校的新生项目课,需要创立一个系统,我们小组选的标题的基于计算机视觉的商品识别系统,那么我们需要一个网站来展示我们的功能,故写这些来记录一下自己,大家如果有什么问题的话…...
23.OpenCV轮廓逼近与拟合
OpenCV轮廓逼近与拟合 在计算机视觉中,轮廓是图像中边界或形状的重要表达形式。然而,直接从图像中提取的轮廓常常包含大量冗余点,且噪声较多。为了更好地描述图像中的形状,我们通常需要对轮廓进行逼近和拟合,从而降低…...
Flutter Row / Column 组件详解
1. 引言 在 Flutter 中,Row 和 Column 是最常用的布局组件,用于在水平方向 (Row) 或垂直方向 (Column) 排列子组件。它们提供了强大的对齐方式、空间分配策略,适用于各种 UI 设计需求。本文将详细介绍它们的基本用法、主要属性及自定义样式。…...
WHAT - 表单场景 - 依赖联动
目录 示例场景技术栈示例代码功能点总结详情场景 - 依赖联动初始化示例说明:详情页场景(含回显、联动)修改点说明示例代码(详情页)总结一下关键点 下面是一个基于 React TypeScript Ant Design (antd) 的表单联动示例…...
SecProxy - 自动化安全协同平台
本人为甲方安全人员,从事甲方工作近6年;针对在甲方平时安全工作的一些重复、复杂、难点的工作,思考如何通过AI、脚本、或者工具实现智能且自动化,于是花平时空闲时间准备将这些能力全部集中到一个平台,于是有了这个东西…...
网络3 子网掩码 划分ip地址
1.根据子网掩码判断主机数 IP地址网络位主机位 核心:将主机位划分为子网位和主机位 疑问:子网位有什么作用 子网掩码:网络位全为1,主机位全为0 主机数2^主机位 -2 2.根据主机和子网判断子网掩码 有一个B类网络145.38.0.0需要划…...
电容详解:定义、作用、分类与使用要点
一、电容的基本定义 电容(Capacitor) 是由两个导体极板(正负极)和中间绝缘介质组成的储能元件,其基本特性为存储电荷。 公式: C Q / V C:电容值(单位:法拉F)…...
Sublime Text for Mac v4.0 【注册汉化版】代码编辑器
Sublime Text for Mac v4.0 【注册汉化版】代码编辑器 一、介绍 sublime text for Mac一款轻量级的文本编辑器,拥有丰富的功能和插件。它支持多种编程语言,包括C、Java、Python、Ruby等,可以帮助程序员快速编写代码。Sublime Text的界面简洁…...
OpenCV 进阶实战与技巧——图像处理的全面解析
在上篇文章中,我们一起迈入了 Python OpenCV 的奇妙世界,学习了图像的读取、显示和保存等基本操作:用Python和OpenCV开启图像处理魔法之旅-CSDN博客。今天,我们将继续深入,探索图像的各种变换、滤波、边缘检测以及更深…...
单细胞转录组-生物标志物篇 | 从异质性描绘到筛查应用
宫颈癌(Cervical cancer, CC)是一种常见的妇科恶性肿瘤。尽管目前的筛查方法已被证明有效并显著降低了CC的发病率和死亡率,但仍然存在缺陷。单细胞RNA测序可以在单细胞分辨率下鉴定复杂和稀有的细胞群。通过scRNA-seq,已经绘制和描…...
MQTT:深入剖析 paho.mqtt.embedded - c - master 目录结构
引言 在嵌入式开发领域,消息队列遥测传输(MQTT)协议因其轻量级、低带宽消耗等特性被广泛应用。Eclipse Paho 项目提供了多种语言的 MQTT 客户端实现,其中paho.mqtt.embedded - c - master是针对 C 语言在嵌入式环境下的 MQTT 客户…...