文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Pig怎么实现关键词匹配

2023-06-02 05:36

关注

本篇文章为大家展示了Pig怎么实现关键词匹配,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1. 问题描述

收集日志avro数据中有两个Map字段appInstall、appUse分别表示已安装的app、正在使用的app,且key值为app的名称,value值为app使用信息。现在要得到一份匹配上购物类app支付宝|京东|淘宝|天猫的用户名单;MapReduce 解决办法如下:

public static class M extends Mapper{    Text text = new Text();        @SuppressWarnings("unchecked")    @Override    protected void map(String key, Pair value, Context context) throws IOException, InterruptedException {        Map data = value.fields.data;                String dvc = data.get("dvc").toString();        MapappInstall = (Map) data.get("appInstall");        MapappUse = (Map) data.get("appUse");                for(String app: appInstall.keySet()) {            if(app.matches("支付宝|京东|淘宝|天猫")) {                text.set(appInstall.keySet().toString());                context.write(dvc, text);                return;            }        }                for(String app: appUse.keySet()) {            if(app.matches("支付宝|京东|淘宝|天猫")) {                text.set(appUse.keySet().toString());                context.write(dvc, text);                return;            }        }    }}

但是,如果要匹配游戏类的app、金融类的app类呢?如果匹配关键词发生了变化呢?显然,我们应该将匹配关键词开放成API,可以自由地匹配正则表达式。这时,pig派上了用场。

2. Bag正则匹配

A = load '//' using org.apache.pig.piggybank.storage.avro.AvroStorage();-- A: {key: chararray,value: (fields: (data: map[]))}B = foreach A generate value.fields.data#'dvc' as dvc, value.fields.data#'appInstall' as ins:map[], value.fields.data#'appUse' as use:map[];-- B: {dvc: bytearray,ins: map[],use: map[]}C = foreach B generate dvc, KEYSET(ins) as insk, KEYSET(use) as usek;-- C: {dvc: bytearray,insk: {(chararray)},usek: {(chararray)}}

在上述代码中,load 数据转换得到bag类型的app-set(insk与usek);但是,应如何遍历bag中的tuple与正则表达式做匹配呢?答案是UDF。

Apache DataFu Pig 提供了丰富的UDF,其中关于bags的UDF可以参看这里。TupleFromBag 提供根据index从bag提取tuple,支持三个输入参数。依葫芦画瓢,遍历bag匹配正则表达式的UDF如下:

package com.pig.udf.bag;public class BagMatchRegex extends FilterFunc {    @Override    public Boolean exec(Tuple tinput) throws IOException {        try{            DataBag samples = (DataBag) tinput.get(0);            String regex = (String) tinput.get(1);            for (Tuple tuple : samples) {                if(((String) tuple.get(0)).matches(regex)){                    return true;                }            }        }        catch (Exception e) {            return false;        }        return false;    }}

其中,FilterFunc为过滤UDF的基类,继承于EvalFunc,即exec(Tuple tinput)的返回值必为Boolean类型。bag正则匹配的pig脚本如下:

REGISTER ../piglib/udf-0.0.1-SNAPSHOT-jar-with-dependencies.jardefine BagMatchRegex com.pig.udf.bag.BagMatchRegex();A = load '/user/../currentpublic class KeyMatchRegex extends FilterFunc {        @SuppressWarnings("unchecked")    @Override    public Boolean exec(Tuple input) throws IOException    {        try{            Mapm = null;            // Input must be of type Map. This is verified at compile time            m = (Map)(input.get(0));                        String regex = (String) input.get(1);            for (String key : m.keySet()) {                if(key.matches(regex)){                    return true;                }            }        }        catch (Exception e) {            return false;        }        return false;    }}

上述内容就是Pig怎么实现关键词匹配,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯