百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

excel vbnet处理实例(金额均分求和,采用字典累加)

yuyutoo 2024-10-12 01:34 7 浏览 0 评论


日期

工作类型

送货金额

人员姓名

2021.8.1

送货

35000

张三,李四,王二,小王

2021.8.2

送货

35001

张三,李四,王二

2021.8.3

送货

35002

张三,李四

2021.8.4

送货

35003

张三

2021.8.5

送货

35004

张三,李四,王二,小王

2021.8.6

送货

35005

张三,李四,王二,小王

2021.8.7

送货

35006

张三,李四

2021.8.8

送货

35007

张三,李四

2021.8.9

送货

35008

张三

2021.8.10

送货

35009

张三,李四,王二

任务要求:快速汇总每一位送货人员的送货金额。注意:送货金额依据人员系数进行平分。要求求得每个人的送货金额数

Dim ws = (New excel).activesheet
        Dim arr = ws.CurrentRegion(3, "A").value
‘arr获取到A3区域,注意包含标题头
        Dim sz() As String
        Dim qian As Single‘定义钱数,考虑到钱有小数,使用single,不能使用整数
        ’定义一个字典,键为string类型存储姓名,值为钱数,使用single浮点数
        Dim dict As New Dictionary(Of String, Single)
        Dim r As Integer
        ’从第2行开始(除开标题)进入主循环
        For r = 2 To UBound(arr)
            sz = arr(r, 4).ToString.Split(",")‘对第4列名单拆解成数组sz
            qian = Val(arr(r, 3)) / sz.Length '钱数平分,Val(arr(r, 3))表示总钱数,sz.Length表示名单个数

            For i = 0 To UBound(sz)
                If Not dict.ContainsKey(sz(i)) Then ‘’对名单中每个姓名进行查找,如果在字典中没找到
                    dict.Add(sz(i), qian)’ 就直接添加
                Else
                    dict(sz(i)) = dict(sz(i)) + qian  如果找到就累加到值
                End If
            Next
        Next

        '输出到listbox查看
        r = 4
        For Each d In dict
            ListBox1.Items.Add(d.Key + "  " + CStr(d.Value))
  ‘这行是输出到界面方便中期调试使用,如果正确再输出到表格
            '输出到表格F G列中
            ws.Setcell(r, "F", d.Key)
            ws.Setcell(r, "G", d.Value)
            r = r + 1
        Next


        'Me.Text = CStr(UBound(arr, 1)) + "  " + CStr(UBound(arr, 2))
    End Sub

知识要点:

字典是一个键-值对,一个键对应一个值。

键1  => 值1
键2  => 值2
键3  => 值4
.....
键n  => 值n
’定义一个字典,键为string类型存储姓名,值为钱数,使用single浮点数
        Dim dict As New Dictionary(Of String, Single)
If Not dict.ContainsKey(sz(i)) Then ‘’对名单中每个姓名进行查找,如果在字典中没找到
                    dict.Add(sz(i), qian)’ 就直接添加
                Else
                    dict(sz(i)) = dict(sz(i)) + qian  如果找到就累加到值
                End If

ContainsKey是查找是否包括键,

dict(sz(i))获得字典值,dict(sz(i)) = dict(sz(i)) + qian直接在值上累加钱。

相关推荐

自卑的人容易患抑郁症吗?(自卑会导致抑郁吗)

Filephoto[Photo/IC]Lowself-esteemmakesusfeelbadaboutourselves.Butdidyouknowthatovert...

中考典型同(近)义词组(同义词考题)

中考典型同(近)义词组...

WPF 消息传递简明教程(wpf messagebox.show)

...

BroadcastReceiver的原理和使用(broadcast-suppression)

一、使用中注意的几点1.动态注册、静态注册的优先级在AndroidManifest.xml中静态注册的receiver比在代码中用registerReceiver动态注册的优先级要低。发送方在send...

Arduino通过串口透传ESP 13板与java程序交互

ESP13---是一个无线板子,配置通过热点通信Arduino通过串口透传ESP13板与java程序交互...

zookeeper的Leader选举源码解析(zookeeper角色选举角色包括)

作者:京东物流梁吉超zookeeper是一个分布式服务框架,主要解决分布式应用中常见的多种数据问题,例如集群管理,状态同步等。为解决这些问题zookeeper需要Leader选举进行保障数据的强一致...

接待外国人英文口语(接待外国友人的英语口语对话)

接待外国人英文口语询问访客身份:  MayIhaveyourname,please?  请问您贵姓?  Whatcompanyareyoufrom?  您是哪个公司的?  Could...

一文深入理解AP架构Nacos注册原理

Nacos简介Nacos是一款阿里巴巴开源用于管理分布式微服务的中间件,能够帮助开发人员快速实现动态服务发现、服务配置、服务元数据及流量管理等。这篇文章主要剖析一下Nacos作为注册中心时其服务注册与...

Android面试宝典之终极大招(android面试及答案)

以下内容来自兆隆IT云学院就业部,根据多年成功就业服务经验,以及职业素养课程部分内容,归纳总结:18.请描述一下Intent和IntentFilter。Android中通过Intent...

除了Crontab,Swoole Timer也可以实现定时任务的

一般的定时器是怎么实现的呢?我总结如下:1.使用Crontab工具,写一个shell脚本,在脚本中调用PHP文件,然后定期执行该脚本;2.ignore_user_abort()和set_time_li...

Spark源码阅读:DataFrame.collect 作业提交流程思维导图

本文分为两个部分:作业提交流程思维导图关键函数列表作业提交流程思维导图...

使用Xamarin和Visual Studio开发Android可穿戴设备应用

搭建开发环境我们需要做的第一件事情是安装必要的工具。因此,你需要首先安装VisualStudio。如果您使用的是VisualStudio2010,2012或2013,那么请确保它是一个专业版本或...

Android开发者必知的5个开源库(android 开发相关源码精编解析)

过去的时间里,Android开发逐步走向成熟,一个个与Android相关的开发工具也层出不穷。不过,在面对各种新鲜事物时,不要忘了那些我们每天使用的大量开源库。在这里,向大家介绍的就是,在这个任劳任怨...

Android事件总线还能怎么玩?(android实现事件处理的步骤)

顾名思义,AndroidEventBus是一个Android平台的事件总线框架,它简化了Activity、Fragment、Service等组件之间的交互,很大程度上降低了它们之间的耦合,使我们的代码...

Android 开发中文引导-应用小部件

应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...

取消回复欢迎 发表评论: