浅谈Excel及Excel VBA在水文测验方式方法创新中几点应用.docVIP

浅谈Excel及Excel VBA在水文测验方式方法创新中几点应用.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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

文档评论(0)

3471161553 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档