如何在 Azure Purview 中为数据分类创建列名模式匹配?

问题描述

如果列名包含以下任何一项,我想要做的只是将字段归类为“出生日期”:

  • 出生日期
  • 出生日期
  • 出生
  • YMDBIRTH

我不是一个庞大的 RegEx 用户,但我通常可以通过一些谷歌来弄清楚。我在自定义数据分类规则中尝试了以下所有内容:

DateofBirth|BirthDate|DOB|YMDBIRTH

/DateofBirth/|/BirthDate/|/DOB/|/YMDBIRTH/

.*DateOfBirth.*|.*BirthDate.*|.*DOB.*|.*YMDBIRTH.*

/.*DateOfBirth.*|.*BirthDate.*|.*DOB.*|.*YMDBIRTH.*/i

这些似乎都不起作用……我开始认为这与我的扫描有关……是否存在某种滞后?

我什至只是在分类规则上使用了 YMDBIRTH,扫描完成后它仍然没有对列进行分类。

根据此 Microsoft 文档,我认为我在此处记录的第一种方法应该有效“DateofBirth|BirthDate|DOB|YMDBIRTH

https://docs.microsoft.com/en-us/azure/purview/create-a-custom-classification-and-classification-rule

根据文件说:

可选地,如果数据通常位于他们知道名称的列中,例如 Employee_ID 或 EmployeeID,他们可以添加列模式正则表达式以使扫描更加准确。一个示例正则表达式是 Employee_ID|EmployeeID

所以使用这个,我认为应该有效: Classification Rule Screenshot

解决方法

由于我们数据库中的命名约定,我们必须变得更有创意,因为列的名称类似于 fs_address 或 address1、FP_address2、address_line3。这是我用来匹配地址相关字段的列名之类的地址

/\w*address\w*|\w*street\w*|\w*city\*w|\w*country\w*|\w*postal\w*|\w*prov\w*/i

\w 匹配任何单词字符(相当于 [a-zA-Z0-9_])

* 在零次和无限次之间匹配前一个标记 这允许模式将 PR_ADDRESS_line1 匹配到 /\waddress\w

最后的 /i 使其不区分大小写

希望能帮到你

,

我不知道这一点,但在扫描规则集中,如果您创建一个新的自定义规则,您认为它会替换系统规则,并且取消选中系统规则.似乎扫描规则不会应用您的自定义规则...

对我来说,我没有选中出生日期系统规则,在检查它(连同我的自定义规则)后,它可以正常工作并对列进行正确分类

见截图:Selected Classification Rules

此外,我的第一种分类方法 DateofBirth|BirthDate|DOB|YMDBIRTH 是正确的,并且在此之后工作得很好。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...