- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浅谈Excel及Excel VBA在水文测验方式方法创新中几点应用
浅谈Excel及Excel VBA在水文测验方式方法创新中几点应用
摘要:Excel电子表格现在已经是我们工作必不可少的工具了,虽然现在在功能上有比它更加强大的平台(Visual Basic 6.0和现在广泛使用的.NET平台),但是在水文资料分析上Excel却有它独特的优点,更能体现出它的灵活、便捷、精确的特点。下面我谈一下我在工作中对Excel的几点认识,希望各位批评指正!
关键词:方式方法创新 电子表格 函数 VBA
1、如何应用已知工具,和在其中进行查询、插补、筛选的功能。
1.1 查询功能
在A、B、C 3列为大断面原始数据,分别为点号、起点距、高程。为了查询河底高程的最低点即D2中的公式为:“=MIN(C2:C56)”;E2中的公式为:
“=MATCH(D2,C2:C100,0)”即查询河底高程最低点所在的起点距位置。
1.2 在大断面上插补测流的左右水边,公式及功能如下
E3为测流水位,F3中公式为:=MATCH(E3,C2:C56,-1),功能为查询测流水位在断面上的位置;F4中公式为:=INDEX(C2:C100,F3),功能为查询F3对应的河底高程;即根据查询、引用、插补功能查询出左右水边。
1.3 数据的筛选功能
在Excel中有着强大的数据筛选功能,主要分为自动筛选和高级筛选。特别是自动筛选中的自定义筛选
功能比较强大,在水位自记固存数据格式中分别是日期、时分、水位,原始数据为6分钟要筛选出半小时的数据,筛选原理即为TIME列等于??:30或者等于??:00。用?表示单个字符;*表示多个字符串,可以是一个字符也可以是几个字符。
2、 VBA在校核水尺检校资料上的应用。
本功能为利用excel vba 的功能对水尺零点高程测量成果进行校核。利用宏这个平台,在VBA的基础上对电子表格进行判断、调用、计算、成果输出。成果表见水文普通测量规范SL58/93附录A中水尺零点高程测量记载表与填制说明。
2.1 过程分析
A-G列为原始观测数据,即起校点为白校8,中间有转点,目的是对TP3进行校核。计算转点高程用后视中丝和前视中丝进行,计算水尺高程间视数据。宏编辑中首先要判断转点、水尺和结束的位置,主要分为视距计算、往测、返测计算。
2.2 源代码数据
Function Roundu(a, b)
见第四部分
End Function
Sub cal()
i = 3
dataend = 0 结束位置
Localtion = 0 转点位置
For i = 3 To 100 查找转点与结束位置
If Not (IsEmpty(Cells(i, 2))) Then
If Cells(i, 2) = Cells(i + 2, 2) Then
Localtion = i
End If
i = i + 1
Else
dataend = i
Exit For
End If
Next i
计算往测
baseback_b = Cells(3, 5) 往测黑面基准数值
baseback_r = Cells(4, 5) 往测红面基准数值
baseh = Cells(3, 12)
For i = 5 To Localtion
If IsEmpty(Cells(i, 6)) Then
h_b = baseback_b - Cells(i, 7)
h_r = baseback_r - Cells(i + 1, 7)
Else
h_b = baseback_b - Cells(i, 6)
h_r = baseback_r - Cells(i + 1, 6)
End If
If h_b 0 Then
Cells(i, 8) = h_b / 1000
Else
Cells(i, 9) = h_b / 1000
End If
If h_r 0 Then
Cells(i + 1, 8) = h_r / 1000
Else
Cells(i + 1, 9) = h_r / 1000
End If
avgh = Roundu((h_b / 1000 + h_r / 1000) / 2, 3)
If avgh 0 Then
Cells(i, 10) = avgh
Else
Cells(i, 11) = avgh
您可能关注的文档
最近下载
- 西门子变频器V20说明书SINAMICS-V20.pdf VIP
- 气血疏通中级班讲义.pdf VIP
- 台湾农民的退休制度.docx VIP
- 夫妻关系讲座课件.pptx
- (人教版)初中九年级化学上册第五单元《化学方程式》综合复习测试训练试题卷(附答案详解).docx VIP
- 1_东南营小学体育课教案水平一潘建元2(1)-体育1至2年级全一册教案.docx VIP
- 人教版2025秋小学数学三年级教学设计已知一个数的几倍是多少,求这个数.pdf VIP
- 人教版2025秋小学数学三年级教学设计求一个数的几倍是多少.pdf VIP
- 酒店前台UPSELL培训教学课件.pptx VIP
- 人教版2025秋小学数学三年级教学课件数量间的乘除关系求一个数的几倍是多少.pptx VIP
文档评论(0)