vba then 多个(怎样用vba多条件求和)
网络优化工程师在工作中经常需要计算距离一个站点最近的20个小区,但逐个计算过于繁琐。利用VBA编程可以轻松实现这一任务。
准备数据格式和VBA代码
首先,按照指定的格式输入数据。
然后,在VBA编辑器中输入以下代码:
```vba
Sub cell_location()
Dim longitude,latitude, s_longtitude, s_latitude, t_longtitude, t_latitude,distance As Double
Dim max_distance As Long
Dim cell As String
Dim s_maxrow, t_maxrow, maxrow, cellnum, s_rowvar, t_rowvar, rowvar, c_rowvar 等长
Sheets("输出结果").Select
maxrow (Columns(1))
If maxrow > 2 then
Range(Cells(2, 1), Cells(maxrow, 7)).选择
结束如果
Sheets("输入有需求的站点").Select
s_maxrow (Columns(1))
Sheets("输入全网数据").Select
t_maxrow (Columns(1))
如果 s_maxrow < 2 或 t_maxrow < 2然后
MsgBox("不够,输入有需求的节点表或者输入全网数据表中没有数据,请确认!!!")
End If
rowvar 2
For s_rowvar 2 To s_maxrow
s_longitude("输入有需求的节点").Cells(s_rowvar, 2)
s_latitude ("输入有需求的站点").Cells(s_rowvar, 3)
s_row 行变量
max_distance 0
cellnum 1
对于 t_rowvar 2 到 t_maxrow
t_longitude Cells(t_rowvar, 2)
t_latitude Cells(t_rowvar, 3)
distance Sqr(((s_longitude - t_longitude) * 98.22, (s_latitude - t_latitude) * 111.22))
distance (distance * 1000,
0)
If cellnum < 20 then
If distance > max_distance then
max_distance distance
t_row rowvar
End If
("输出结果").Cells(rowvar, 1) ("输入有需求的节点").Cells(s_rowvar, 1)
("输出结果").Cells(rowvar, 2) ("输入有需求的节点").Cells(s_rowvar, 2)
("输出结果").Cells(rowvar, 3) ("输入有需求的节点").Cells(s_rowvar, 3)
("输出结果").Cells(rowvar, 4)距离
("输出结果").Cells(rowvar, 5) ("输入全网数据").Cells(t_rowvar, 1)
("输出结果").Cells(rowvar, 6) ("输入全网数据").Cells(t_rowvar, 2)
("输出结果").Cells(rowvar, 7) ("输入全网数据").Cells(t_rowvar, 3)
rowvar rowvar 1
cellnum cellnum 1
ElseIf distance < max_distanceThen
("输出结果").Cells(t_row, 4) distance
("输出结果").Cells(t_row, 5) ("输入全网数据").Cells(t_rowvar, 1)
("输出结果").Cells(t_row, 6) ("输入全网数据").Cells(t_rowvar, 2)
("输出结果").Cells(t_row, 7) ("输入全网数据").Cells(t_rowvar, 3)
max_distance距离
对于 c_rowvar s_row 到 rowvar - 1
If ("输出结果").Cells(c_rowvar, 4) > max_distance then
max_distance ("输出结果").Cells(c_rowvar, 4)
t_row c_rowvar
End If
Next
End If
Next
Next
Sheets("输出结果").Select
maxrow (Columns(1))
("输出结果")
("输出结果") Key:Range(Cells(2, 1), Cells(maxrow, 1)), SortOn:xlSortOnValues, Order:xlAscending, DataOption:xlSortNormal
("输出结果") Key:Range(Cells(2, 4), Cells(maxrow, 4)), SortOn:xlSortOnValues, Order:xlAscending, DataOption:xlSortNormal
With ("输出结果").Sort
.SetRange Range(Cells(1,1, 1), Cells(maxrow, 7))
.Header xlYes
.MatchCase False
.Orientation xlTopToBottom
.SortMethod xlPinYin
.Apply
End With
Cells(1, 1).Select
End Sub
```
配置并保存文件
1. 将Excel文件保存为启用宏的工作簿,后缀为.XLSM。
2. 插入按钮并指定宏或VBA代码给按钮。
3. 选择VBA代码后,将按钮名称更改为易懂的描述。