周一至周五 : 08:30 - 17:30 客服专员电话/微信:17301649371 QQ:2627049059
微信咨询

扫码微信咨询

关注公众号

关注微信公众号

电话: 021 5161 9370
返回顶部
数量、单价、金额互算VBA
显示全部楼层 正序浏览 发表日期 2016-03-01 10:11:17 16016次阅读 26次回复
数量、单价、金额互算VBA
将下面的代码复制到快表VBA编辑器中测试。代码下面有对应模板下载

  1. Imports SpreadsheetGear
  2. Imports System.Windows.forms
  3. Namespace ExcelViewVBDotnet
  4.     Public Class StandardInterface '自定义名称
  5.         '预留位置1
  6.         '预留位置2
  7.         Dim AW As SpreadsheetGear.IWorkbook,Range As SpreadsheetGear.IRange
  8.         Dim CF,TS,VW As Object,YN As String
  9.         Public Sub Workbook_Open(OldRoot As Object,NewRoot As Object,Excel As SpreadsheetGear.Windows.Forms.WorkbookView)
  10.            Excel.GetLock()
  11.            AW = Excel.ActiveWorkbook
  12.            Range = AW.ActiveWorksheet.Range
  13.            Excel.ReleaseLock()
  14.            '位置:2保存3新增4提交5退回6打印7预览8导出9捕获10上传图片11上传附件12插入行13插多行14删除行15查找16最后
  15.         End Sub'打开时执行事件

  16.         Public Sub RangeSelection(sender As Object,e As SpreadsheetGear.Windows.Forms.RangeSelectionChangedEventArgs)

  17.         End Sub'单元格选择后执行的事件

  18.         Public Sub RangeChanged(sender As Object,e As SpreadsheetGear.Windows.Forms.RangeChangedEventArgs)
  19.                    if e.Range.Address <> YN Then'避免重复触发
  20.                           if e.Range.Intersect(Range("F_30")) IsNot Nothing then'数量触发金额
  21.                              if e.Range.Offset(0,1).Value IsNot Nothing And e.Range.Value IsNot NotHing then
  22.                                 e.Range.Offset(0,2).Value = CType(e.Range.Offset(0,1).Value,Double) * CType(e.Range.Value,Double)        
  23.                              end if
  24.                       Elseif e.Range.Intersect(Range("F_31")) IsNot Nothing then'单价触发金额
  25.                          if e.Range.Offset(0,-1).Value IsNot Nothing And e.Range.Value IsNot NotHing then
  26.                                     YN = E.Range.Offset(0,1).Address
  27.                                 e.Range.Offset(0,1).Value = CType(e.Range.Offset(0,-1).Value,Double) * CType(e.Range.Value,Double)
  28.                              end if  
  29.                       Elseif e.Range.Intersect(Range("F_32")) IsNot Nothing then'金额触发单价
  30.                          if e.Range.Offset(0,-2).Value IsNot Nothing And e.Range.Value IsNot NotHing then
  31.                                     if CType(e.Range.Offset(0,-2).Value,Double) <> 0 then
  32.                                            YN = E.Range.Offset(0,-1).Address
  33.                                    e.Range.Offset(0,-1).Value = CType(e.Range.Value,Double) / CType(e.Range.Offset(0,-2).Value,Double)
  34.                                 end if
  35.                              end if
  36.                       End if
  37.                    Else
  38.                       YN = ""'还原触发判断
  39.                    End if
  40.         End Sub'单元格编辑完成后执行事件

  41.         Public Sub ButtunClick(sender As Object,e As SpreadsheetGear.Windows.Forms.ShapeActionEventArgs)
  42.    
  43.         End Sub'按钮/标签点击事件

  44.         Public Sub FollowHyperlink(sender As Object)
  45.            
  46.         End Sub '暂不支持

  47.     End Class
  48.     '注:除事件字眼下可以自定义代码外的所有代码不允许改动,否则编译将有可能失败。

  49. End Namespace

复制代码

游客,如果您要查看本帖隐藏内容请回复
电话/微信:18049989370 QQ:857188287
看看怎么模板
626002396

2020-11-14 20:00:14

这个功能估计很强大的
tsddb

2020-9-22 13:05:30

靠靠靠靠靠靠靠
bjxcar

2020-4-9 21:45:19

厉害,我的歌,像你学习
看看,想学一点。
学习一下,学习一下学习一下
学习学习,研究一下
来学习一下
7007

2018-7-13 16:27:07

厉害啊!新手学习

精彩评论26

看看怎么模板
626002396

2020-11-14 20:00:14

这个功能估计很强大的
tsddb

2020-9-22 13:05:30

靠靠靠靠靠靠靠
bjxcar

2020-4-9 21:45:19

厉害,我的歌,像你学习
看看,想学一点。
学习一下,学习一下学习一下
学习学习,研究一下
来学习一下
7007

2018-7-13 16:27:07

厉害啊!新手学习
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则  允许回帖邮件提醒楼主

快表软件是国内较早研究表格类软件开发平台的团队之一,迄今已有十多年的行业经验.致力于为企事业单位提供实用可靠的数字化平台。
  • 微信公众号

  • 微信小商店

  • 微信客服

  • Powered by Discuz! X3.4 | Copyright © 2022-2024, XiRong Soft. | 快表软件
  • 沪ICP备13033196号 | 营业执照 |上海西戎软件科技有限公司|沪公网安备31011502002146号|沪ICP备13033196号 |