excel规划求解结合vba宏笔记

目录

概念与配置

规划求解定义

excel设置规划求解

宏的基本操作

excel批量进行规划求解案例

加载规划求解模块

宏的设置

宏录制vba

其他案例


概念与配置

规划求解定义

运用"规划求解"定义并求解问题 - Microsoft 支持

excel设置规划求解

EXCEL规划求解的简明教程 - 知乎 (zhihu.com)

excel中的批量操作可以使用vba宏来进行操作

宏的基本操作

Excel-VBA 快速上手(一、宏、VBA、过程、类型与变量、函数)_excel vba-CSDN博客

复杂的宏可以使用宏录制

Excel 宏教程:录制宏基础 - 懒人Excel (lanrenexcel.com)

使用宏录制器自动执行任务 - Microsoft 支持

excel批量进行规划求解案例

批量处理通常可以使用vba进行编写来实现,通过宏录制结合gpt可以 实现零基础实现复杂的批处理。

加载规划求解模块

通过设置进行规划求解

宏的设置

然后就可以编写了

宏录制vba

自行设置

然后进行规划求解

输入你的约束函数等信息

完成后点击停止录制

就可以看到我们宏录制的vba了

运行代码前需要引入

然后通过gpt进行修改完善

例如我的vba

先随机初始化

复制代码
Sub FillRandomNumbers()
    Dim rng As Range
    Dim cell As Range
    Dim minValue As Double
    Dim maxValue As Double
    
    ' 设置随机数的最小值和最大值
    minValue = 0#
    maxValue = 120#
    
    ' 设置要填充随机数的范围
    Set rng = Range("B2:E89")
    
    ' 遍历每个单元格并填充随机数
    For Each cell In rng
        cell.Value = minValue + (maxValue - minValue) * Rnd
    Next cell
End Sub

Sub OptimizeRows()
    Dim i As Integer

    
    For i = 223 To 224
        ' 设置 Solver 参数
        SolverOk SetCell:="$I$" & i, MaxMinVal:=3, ValueOf:=0, ByChange:="$B$" & i & ":$E$" & i, _
            Engine:=1, EngineDesc:="GRG Nonlinear"
        
        ' 添加 Solver 约束
        SolverAdd CellRef:="$B$" & i & ":$E$" & i, Relation:=1, FormulaText:="100"
        SolverAdd CellRef:="$H$" & i, Relation:=1, FormulaText:="8"
        SolverAdd CellRef:="$H$" & i, Relation:=3, FormulaText:="4"
        
        ' 求解
        SolverSolve
        
        ' 重置 Solver
        SolverReset
    Next i
End Sub

' 重置 Solver
SolverReset

重点注意这个,会重置规划求解。 不然每次都会添加你的约束条件

相当于下图的全部重置

这段VBA代码用于在Excel中利用求解器(Solver)解决优化问题。以下是每部分的解释:

  1. Dim i As Integer : 声明一个整型变量 i,用于循环控制。

  2. For i = 27 To 224: 启动一个循环,从第27行到第224行逐行处理。

  3. SolverOk SetCell:="$I$" & i, MaxMinVal:=3, ValueOf:=0, ByChange:="$B$" & i & ":$E$" & i, Engine:=1, EngineDesc:="GRG Nonlinear": 设置求解器的目标单元格为第i行的I列,优化目标为该单元格的值为0,允许更改B列到E列的单元格,使用"GRG Nonlinear"求解引擎。

  4. SolverAdd CellRef:="$B$" & i & ":$E$" & i, Relation:=1, FormulaText:="100": 为第i行的B列到E列单元格设置一个约束条件,要求这些单元格的值不超过100。

  5. SolverAdd CellRef:="$H$" & i, Relation:=1, FormulaText:="8": 为第i行的H列单元格设置一个约束条件,要求该单元格的值不超过8。

  6. SolverAdd CellRef:="$H$" & i, Relation:=3, FormulaText:="4": 为第i行的H列单元格设置另一个约束条件,要求该单元格的值至少为4。

  7. SolverSolve: 执行求解器计算以找到满足所有约束条件的最优解。

  8. Next i: 结束当前循环,继续到下一行。

这样,代码会对每一行应用相同的求解器设置和约束条件,并寻找每一行的最优解。

其他案例

Excel规划求解的vba调用_规划求解 vba-CSDN博客

相关推荐
摇滚侠5 分钟前
2025最新 SpringCloud 教程,教程简介,笔记01
笔记·spring cloud
RickyWasYoung2 小时前
【笔记】智能汽车、电动汽车政策文件
笔记·汽车
johnny2334 小时前
智能电子表格:Airtable、NocoDB、teable、APITable
excel
love530love5 小时前
【保姆级教程】Windows + Podman 从零部署 Duix-Avatar 数字人项目
人工智能·windows·笔记·python·数字人·podman·duix-avatar
草莓熊Lotso6 小时前
《算法闯关指南:动态规划算法--斐波拉契数列模型》--01.第N个泰波拉契数,02.三步问题
开发语言·c++·经验分享·笔记·其他·算法·动态规划
2501_9307077810 小时前
如何使用C#代码在Excel 文件中添加工作表
excel
FFF团团员90913 小时前
树莓派学习笔记3:LED和Button
笔记·学习
碧海潮生_CC14 小时前
【CUDA笔记】04 CUDA 归约, 原子操作,Warp 交换
笔记·cuda
摇滚侠14 小时前
2025最新 SpringCloud 教程,从单体到集群架构,笔记02
笔记·spring cloud·架构
风123456789~15 小时前
【OceanBase专栏】OB背景知识
数据库·笔记·oceanbase