热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Excel使用vba按颜色验证-Excelvalidatebycolorswithvba

Ineedtocheckifaperson(1,2,3,4,5)haveauthorizationtousesomeproduct(A,B,C,D,E),

I need to check if a person (1, 2, 3, 4, 5) have authorization to use some product (A, B, C, D, E), so i have this: Check

我需要检查一个人(1,2,3,4,5)是否有权使用某些产品(A,B,C,D,E),所以我有这个:

and have this authorizations table:

并拥有此授权表:

Table

so i need, after insert the letter and the number, have a Yes or No Authorization.

所以我需要,插入字母和数字后,有一个是或否授权。

2 个解决方案

#1


Paste the public function into a vba module in your workbook and then use it directly in your worksheet as a formula "getAuth(...)".

将公共函数粘贴到工作簿中的vba模块中,然后直接在工作表中将其用作公式“getAuth(...)”。

Parameters used:

  • Letter: Range with the letter
  • 信:范围与信

  • Number: Range with the number
  • 数字:带数字的范围

  • AuthRange: Range with the Authentication data (the table with the colors)
  • AuthRange:带有身份验证数据的范围(带颜色的表)

  • YesColor: Range with the color used for Yes (uses the background color)
  • YesColor:使用Yes的颜色范围(使用背景颜色)

Public Function getAuth(Letter As Range, Number As Range, _
AuthRange As Range, YesColor As Range) As String
    Dim rng As Range
    With AuthRange
        Set rng = .Cells(WorksheetFunction.Match(Number, .Columns(1), 0), _
            WorksheetFunction.Match(Letter, .Rows(1), 0))
        getAuth = IIf(rng.Interior.Color = YesColor.Interior.Color, "Yes", "No")
    End With
End Function

#2


You can use something like this directly into your workbook (more details below) :

您可以将这样的内容直接用于您的工作簿(下面有更多详细信息):

Public Function Get_Auth(ByVal User As String, ByVal Product As String) As String
Dim A()
A = ThisWorkbook.Sheets("Feuil1").Range("DB_Prod").Value

For i = LBound(A, 1) To UBound(A, 1)
    For j = LBound(A, 2) To UBound(A, 2)
        If A(i, 1) <> User And A(1, j) <> Product Then
        Else
            'If interior is different of red (use macro recorder to get your own color reference)
            If ThisWorkbook.Sheets("Feuil1").Cells(i, j).Interior.Color <> 255 Then
                'If interior is different of green
                If ThisWorkbook.Sheets("Feuil1").Cells(i, j).Interior.Color <> 5287936 Then
                    'Not handled
                Else
                    Get_Auth = "Yes"
                End If
            Else
                Get_Auth = "No"
            End If
        End If
    Next j
Next i

End Function

First you need to set a name for your authorization table (I used "DB_Prod"), or specify the address of the table ($A$1:$C$10) and change the Sheet name into the code :

首先,您需要为授权表设置一个名称(我使用“DB_Prod”),或者指定表的地址($ A $ 1:$ C $ 10)并将Sheet名称更改为代码:

A = ThisWorkbook.Sheets("Feuil1").Range("DB_Prod").Value

A = ThisWorkbook.Sheets(“Feuil1”)。范围(“DB_Prod”)。值

Then activate macro recorder and change 2 cells color, one to green, one to red to identify the specific colors that you use and change it into the code :

然后激活宏录制器并更改2个单元格颜色,一个更改为绿色,一个更改为红色以标识您使用的特定颜色并将其更改为代码:

If ThisWorkbook.Sheets("Feuil1").Cells(i, j).Interior.Color <> 5287936 (green color)

如果ThisWorkbook.Sheets(“Feuil1”)。Cells(i,j).Interior.Color <> 5287936(绿色)

Then you can type directly into your workbook : =Get_Auth(A2,C1)

然后你可以直接输入你的工作簿:= Get_Auth(A2,C1)

Enjoy!


推荐阅读
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了[从头学数学]中第101节关于比例的相关问题的研究和修炼过程。主要内容包括[机器小伟]和[工程师阿伟]一起研究比例的相关问题,并给出了一个求比例的函数scale的实现。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
author-avatar
海边的迷思萝_160
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有