• Kettle 使用JS脚本 增加UUID输出列


    本文转载:https://www.jianshu.com/p/d105ae70b15d

    Kettle 使用JS脚本 增加UUID输出列

     
     
    ####JavaScript 脚本如下####################################################
    
    //Script here
    
    function UUID(){  
        this.id = this.createUUID();  
    }  
      
    UUID.prototype.valueOf = function(){ return this.id; }  
    UUID.prototype.toString = function(){ return this.id; }  
      
    UUID.prototype.createUUID = function(){  
        var dg = new Date(1582, 10, 15, 0, 0, 0, 0);  
        var dc = new Date();  
        var t = dc.getTime() - dg.getTime();  
        var h = '';  
        var tl = UUID.getIntegerBits(t,0,31);  
        var tm = UUID.getIntegerBits(t,32,47);  
        var thv = UUID.getIntegerBits(t,48,59) + '1';  
        var csar = UUID.getIntegerBits(UUID.rand(4095),0,7);  
        var csl = UUID.getIntegerBits(UUID.rand(4095),0,7);  
      
        var n = UUID.getIntegerBits(UUID.rand(8191),0,7) +   
                UUID.getIntegerBits(UUID.rand(8191),8,15) +   
                UUID.getIntegerBits(UUID.rand(8191),0,7) +   
                UUID.getIntegerBits(UUID.rand(8191),8,15) +   
                UUID.getIntegerBits(UUID.rand(8191),0,15);   
        return tl + h + tm + h + thv + h + csar + csl + h + n;   
    }  
      
    UUID.getIntegerBits = function(val,start,end){  
        var base16 = UUID.returnBase(val,16);  
        var quadArray = new Array();  
        var quadString = '';  
        var i = 0;  
        for(i=0;i<base16.length;i++){  
            quadArray.push(base16.substring(i,i+1));      
        }  
        for(i=Math.floor(start/4);i<=Math.floor(end/4);i++){  
            if(!quadArray[i] || quadArray[i] == '') quadString += '0';  
            else quadString += quadArray[i];  
        }  
        return quadString;  
    }  
      
    UUID.returnBase = function(number, base){  
          
        var convert = ['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];  
        if (number < base) var output = convert[number];  
        else {  
            var MSD = '' + Math.floor(number / base);  
            var LSD = number - MSD*base;  
            if (MSD >= base) var output = this.returnBase(MSD,base) + convert[LSD];  
            else var output = convert[MSD] + convert[LSD];  
        }  
        return output;  
    }  
      
    UUID.rand = function(max){  
        return Math.floor(Math.random() * max);  
    }  
      
    var ID=new UUID().id;  
    
    ##############################################################
    

      

    测试数据如下:

     
  • 相关阅读:
    Android Wear(手表)开发
    Android 中文件类型与MIME的匹配表
    匹配字符串-好技能-正则表达式
    正则表达式匹配字符串
    如何开发Android Wear应用程序
    【转】 hive安装配置及遇到的问题解决
    Hadoop项目开发环境搭建(EclipseMyEclipse + Maven)
    MapReduce 开发环境搭建(EclipseMyEclipse + Maven)
    hive权威安装出现的不解错误!(完美解决)两种方法都可以
    Hive项目开发环境搭建(EclipseMyEclipse + Maven)
  • 原文地址:https://www.cnblogs.com/drunkPullBreeze/p/13467975.html
Copyright © 2020-2023  润新知