Microsoft VBA Excel VBA学习笔记——双重筛选+复制数值1.0
问题场景
| Country | Product | CLASS 1 | CLASS 2 | CLASS 3 | CLASS 4 | CLASS 5 | CLASS 6 | … |
|---|---|---|---|---|---|---|---|---|
| US | Apple | 0.364141603 | 0.891821061 | 0.059145199 | 0.732011029 | 0.050963656 | 0.222464259 | … |
| US | Banana | 0.230083333 | 0.402726218 | 0.154883667 | 0.298890486 | 0.780232621 | 0.028592635 | … |
| CN | Apple | 0.776237047 | 0.507554832 | 0.481978786 | 0.964094710 | 0.635608483 | 0.650148065 | … |
| CN | Banana | 0.314416117 | 0.865829827 | 0.838746225 | 0.584803658 | 0.632143938 | 0.635900146 | … |
| HK | Apple | 0.038955013 | 0.537686547 | 0.396884228 | 0.646283709 | 0.980316357 | 0.729927410 | … |
| HK | Banana | 0.929699567 | 0.875914643 | 0.855651289 | 0.349502863 | 0.778827116 | 0.056140485 | … |
| US | Orange | 0.637295510 | 0.966399457 | 0.102005751 | 0.345379154 | 0.182812383 | 0.255992180 | … |
| US | Strawberry | 0.937893889 | 0.151947906 | 0.234707740 | 0.626308424 | 0.804376439 | 0.138557531 | … |
| CN | Orange | 0.589701555 | 0.029821538 | 0.324999202 | 0.138480401 | 0.410818109 | 0.181386365 | … |
| CN | Strawberry | 0.587089886 | 0.870334801 | 0.050660711 | 0.712157225 | 0.946011122 | 0.286730440 | … |
| HK | Orange | 0.884634243 | 0.896100687 | 0.675844393 | 0.355247262 | 0.498187742 | 0.325255134 | … |
| HK | Strawberry | 0.697344394 | 0.423227932 | 0.650203362 | 0.560784327 | 0.298141331 | 0.186946272 | … |
简述:
其实很简单的操作,就是两次筛选后复制Item1全部数据到Item2中,两个Item有且只有一行。
草稿1
- 打开工作表:通过工作表名称来定位和激活工作表。
- 定位筛选判断列:在第一行中找到Product的列,然后进行筛选。
- 筛选指定名称:首先筛选出包含 name1 “Apple”和name2“Banana”的行。
- **再次筛选Country **:在筛选出的结果中,基于Country (US、HK、CN)进行进一步筛选并复制数据。
Function FilterAndCopyData(sheetName As String, columnName As String, name1 As String, name2 As String)Dim ws As WorksheetDim filterColumn As LongDim lastRow As LongDim i As Long' 尝试访问工作表On Error Resume NextSet ws = ThisWorkbook.Worksheets(sheetName)On Error GoTo 0If ws Is Nothing ThenMsgBox "工作表 '" & sheetName & "' 不存在。", vbExclamationExit FunctionEnd If' 找到筛选判断列filterColumn = 0For i = 1 To ws.Cells(1, ws.Columns.Count).End(xlToLeft).ColumnIf ws.Cells(1, i).Value = columnName ThenfilterColumn = iExit ForEnd IfNext iIf filterColumn = 0 ThenMsgBox "列 '" & columnName & "' 没有找到。", vbExclamationExit FunctionEnd If' 清除现有筛选If ws.AutoFilterMode Then ws.AutoFilterMode = False' 应用筛选ws.Range("A1").AutoFilter Field:=filterColumn, Criteria1:=name1ws.Range("A1").AutoFilter Field:=filterColumn, Criteria2:=name2' 复制数据lastRow = ws.Cells(ws.Rows.Count, filterColumn).End(xlUp).RowFor i = 2 To lastRowIf ws.AutoFilter.Range.Rows(i).Hidden = False ThenIf ws.Cells(i, filterColumn).Value = name1 Then' 找到产地并复制数据Select Case ws.Cells(i, "A").ValueCase "US", "HK", "CN"' 复制C列以后的数据到Banana对应行ws.Cells(i, "C").Resize(1, ws.Columns.Count - 3).CopyFor j = 2 To lastRowIf ws.Cells(j, filterColumn).Value = name2 And ws.Cells(j, "A").Value = ws.Cells(i, "A").Value Thenws.Cells(j, "C").PasteSpecial Paste:=xlPasteValuesEnd IfNext jEnd SelectEnd IfEnd IfNext i' 关闭筛选If ws.AutoFilterMode Then ws.AutoFilterMode = FalseMsgBox "数据复制完成。"
End Function
草稿2
- 接受工作表名称、列名称、以及两个筛选值作为参数。
- 在指定的工作表上执行筛选操作。
- 对筛选后的数据,按国家分类,将指定类别(Apple)的数值复制到另一个类别(Banana)中。
Sub CopyValuesBasedOnClassAndCountry(wsName As String, columnName As String, value1 As String, value2 As String)Dim ws As WorksheetDim lastRow As Long, i As LongDim countryCol As Integer, classCol As Integer, col As IntegerDim dataRange As Range, cell As RangeDim country As StringDim dict As ObjectSet dict = CreateObject("Scripting.Dictionary")' 设置工作表Set ws = ThisWorkbook.Worksheets(wsName)' 确定总行数lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row' 查找国家和分类列的索引For i = 1 To ws.Cells(1, ws.Columns.Count).End(xlToLeft).ColumnIf ws.Cells(1, i).Value = "Country" ThencountryCol = iElseIf ws.Cells(1, i).Value = columnName ThenclassCol = iEnd IfNext i' 遍历所有行For i = 2 To lastRowIf (ws.Cells(i, classCol).Value = value1 Or ws.Cells(i, classCol).Value = value2) Thencountry = ws.Cells(i, countryCol).ValueIf Not dict.Exists(country) ThenSet dict(country) = New CollectionEnd Ifdict(country).Add iEnd IfNext i' 复制数值For Each key In dict.KeysDim appleRow As LongDim bananaRow As LongFor Each idx In dict(key)If ws.Cells(idx, classCol).Value = "Apple" Then appleRow = idxIf ws.Cells(idx, classCol).Value = "Banana" Then bananaRow = idxNextFor col = 3 To ws.Cells(1, ws.Columns.Count).End(xlToLeft).Columnws.Cells(bananaRow, col).Value = ws.Cells(appleRow, col).ValueNext colNextMsgBox "数据已经根据指定的规则复制完成。"
End Sub
总结
寻找最佳的方案中》》》
相关文章:
Microsoft VBA Excel VBA学习笔记——双重筛选+复制数值1.0
问题场景 CountryProductCLASS 1CLASS 2CLASS 3CLASS 4CLASS 5CLASS 6…USApple0.3641416030.8918210610.0591451990.7320110290.0509636560.222464259…USBanana0.2300833330.4027262180.1548836670.2988904860.7802326210.028592635…CNApple0.7762370470.5075548320.481978…...
谷歌反垄断官司败诉后,或又面临被拆分风险?
KlipC报道:上周8月5日,美国法院裁定谷歌的搜索业务违反了美国反垄断法,非法垄断在线搜索和搜索文本广告市场。据悉,胜诉的美国司法部正在考虑拆分谷歌。其他选项包括强制谷歌与竞争对手分享更多数据,以及防止其在人工智…...
数据结构入门——06树
1.树 树(Tree)非线性数据结构,它是n(n≥0)个节点的有限集合,它满足两个条件 : 有且仅有一个特定的称为根(Root)的节点; 其余的节点可以分为m(m…...
FFmpeg源码:av_packet_move_ref、av_packet_make_refcounted函数分析
一、av_packet_move_ref函数 (一)av_packet_move_ref函数的声明 av_packet_move_ref函数声明在FFmpeg源码(本文演示用的FFmpeg源码版本为7.0.1)的头文件libavcodec/packet.h中: /*** Move every field in src to ds…...
12 中断
12 中断 1、内核中断编程2、顶半部和底半部机制2.1 任务的相关概念2.1.1 分类2.1.2 优先级2.1.3 进程调度2.1.4 休眠sleep 2.2 顶半部和底半部实现机制2.2.1 顶半部特点2.2.2 底半部特点2.2.3 底半部实现方法之:tasklet2.2.4 底半部实现机制之工作队列2.2.5 底半部实现机制之软…...
经典算法题总结:十大排序算法,外部排序和Google排序简介
十大排序算法 就地性:顾名思义,原地排序通过在原数组上直接操作实现排序,无须借助额外的辅助数组,从而节省内存。通常情况下,原地排序的数据搬运操作较少,运行速度也更快。 稳定性:稳定排序在完…...
服务器是什么?怎么选择适合自己的服务器?
在这个数字化的世界中,我们每天都在与各种网站打交道,浏览新闻、购物、看视频等。你是否曾经好奇过,这些网站是如何运行的?它们又是如何实现随时随地可访问的呢? 在这背后,有一个神秘的角色在默默地支撑着…...
区块链技术的应用场景
区块链技术是一种分布式数据库或公共分类账的形式,它保证了数据的完整性和透明性。它最初是为了支持比特币这种加密货币而被发明的,但现在已经被广泛应用于多种领域,包括供应链管理、投票系统、数字身份验证等。 基本概念 区块 (Block) 区块…...
凤凰端子音频矩阵应用领域
凤凰端子音频矩阵,作为一种集成了凤凰端子接口的音频矩阵设备,具有广泛的应用领域。以下是其主要应用领域: 一、专业音响系统 会议系统:在会议室中,凤凰端子音频矩阵能够处理多个话筒和音频源的信号,实现…...
LeetCode-字母异位词分组
题目描述 给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例 1: 输入: strs ["eat", "tea", "tan", "ate", "na…...
《Linux运维总结:基于x86_64架构CPU使用docker-compose一键离线部署etcd 3.5.15容器版分布式集群》
总结:整理不易,如果对你有帮助,可否点赞关注一下? 更多详细内容请参考:《Linux运维篇:Linux系统运维指南》 一、部署背景 由于业务系统的特殊性,我们需要面对不同的客户部署业务系统࿰…...
WPF动画
补间动画:动画本质就是在一个时间段内对象尺寸、位移、旋转角度、缩放、颜色、透明度等属性值的连续变化。也包括图形变形的属性。时间、变化的对象、变化的值 工业应用场景:蚂蚁线、旋转、高度变化、指针偏移、小车 WPF动画与分类 特定对象处理动画过…...
大数据系列之:统计hive表的详细信息,生成csv统计表
大数据系列之:统计hive表的详细信息,生成csv统计表 一、获取源数据库、源数据库类型、hive数据库名称二、获取hive数据库名、hive表名、数仓层级、空间、维护者信息三、统计hive表信息四、统计源库信息五、合并hive表信息六、生成csv统计表七、完整代码一、获取源数据库、源数…...
flutter 画转盘
import package:flutter/material.dart; import dart:math;const double spacingAngle 45.0; // 每两个文字之间的角度 // 自定义绘制器,ArcTextPainter 用于在圆弧上绘制文字 class ArcTextPainter extends CustomPainter {final double rotationAngle; // 动画旋…...
图像识别,图片线条检测
import cv2 import numpy as np # 读取图片 img cv2.imread(1.png)# 灰度化 gray cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)# 边缘检测 edges cv2.Canny(gray, 100, 200) 当某个像素点的梯度强度低于 threshold1 时,该像素点被认为是非边缘;当梯度强度…...
python crawler web page
npm install or pip install 插件 import json import time from openpyxl import load_workbook from pip._vendor import requests from bs4 import BeautifulSoup import pandas as pd import re import xlsxwriter 設置request header header {user-agent: Mozilla/5.0…...
基于QT实现的TCP连接的网络通信(客户端)
上篇介绍了QT实现网络通信的服务器端,还没看服务器的朋友们先去上篇了解,这篇我来实现一下客户端的实现。 首先还是新建一个项目 选择mainwindow类 在通信前将.pro文件的第一行代码中追加network 窗口搭建 在mainwindow.ui中完成一下窗口的搭建 首先在…...
Vue2中watch与Vue3中watch对比
上一节说到了 computed计算属性对比 ,虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时&#…...
Web 3 一些常见术语
目录 Provider 提供者Signer 签名者Transaction 交易Contract 合约Receipt 收据 首先,从高层次上对可用对象的类型及其负责的内容有一个基本的了解是很有用的。 Provider 提供者 一个 Provider 是与区块链的只读连接,允许查询区块链状态,例…...
揭开数据分析中的规范性分析:从入门到精通
目录 引言1. 规范性分析的基本概念2. 规范性分析的方法论2.1 线性规划:资源利用最大化2.2 决策树分析:直观的选择路径2.3 贝叶斯网络:应对不确定性的利器2.4 多目标优化:平衡多重目标的艺术 3. 规范性分析的实际应用3.1 商业决策中…...
KubeSphere 容器平台高可用:环境搭建与可视化操作指南
Linux_k8s篇 欢迎来到Linux的世界,看笔记好好学多敲多打,每个人都是大神! 题目:KubeSphere 容器平台高可用:环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...
基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容
基于 UniApp + WebSocket实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
C# SqlSugar:依赖注入与仓储模式实践
C# SqlSugar:依赖注入与仓储模式实践 在 C# 的应用开发中,数据库操作是必不可少的环节。为了让数据访问层更加简洁、高效且易于维护,许多开发者会选择成熟的 ORM(对象关系映射)框架,SqlSugar 就是其中备受…...
计算机基础知识解析:从应用到架构的全面拆解
目录 前言 1、 计算机的应用领域:无处不在的数字助手 2、 计算机的进化史:从算盘到量子计算 3、计算机的分类:不止 “台式机和笔记本” 4、计算机的组件:硬件与软件的协同 4.1 硬件:五大核心部件 4.2 软件&#…...
通过 Ansible 在 Windows 2022 上安装 IIS Web 服务器
拓扑结构 这是一个用于通过 Ansible 部署 IIS Web 服务器的实验室拓扑。 前提条件: 在被管理的节点上安装WinRm 准备一张自签名的证书 开放防火墙入站tcp 5985 5986端口 准备自签名证书 PS C:\Users\azureuser> $cert New-SelfSignedCertificate -DnsName &…...
前端中slice和splic的区别
1. slice slice 用于从数组中提取一部分元素,返回一个新的数组。 特点: 不修改原数组:slice 不会改变原数组,而是返回一个新的数组。提取数组的部分:slice 会根据指定的开始索引和结束索引提取数组的一部分。不包含…...
vue3 daterange正则踩坑
<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...
xmind转换为markdown
文章目录 解锁思维导图新姿势:将XMind转为结构化Markdown 一、认识Xmind结构二、核心转换流程详解1.解压XMind文件(ZIP处理)2.解析JSON数据结构3:递归转换树形结构4:Markdown层级生成逻辑 三、完整代码 解锁思维导图新…...
篇章二 论坛系统——系统设计
目录 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 1. 数据库设计 1.1 数据库名: forum db 1.2 表的设计 1.3 编写SQL 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 通过需求分析获得概念类并结合业务实现过程中的技术需要&#x…...
