EAN校验码的计算方法

末位为校验码

/** 
   EAN码校验位的计算方法 
   从代码位置序号2开始,所有偶数位的数字代码求和为a。 
   将上步中的a乘以3为a。 
   从代码位置序号3开始,所有奇数位的数字代码求和为b。 
   将a和b相加为c。 
   取c的个位数d。 
   用10减去d即为校验位数值。

   例:234235654652的校验码的计算如下表:

   数据码 校验码 
   代码位置序号 13 12 11 10 9 8 7 6 5 4 3 2 1 
   数字码 2 3 4 2 3 5 5 5 4 6 5 2 ? 
   偶数位     3 + 2 + 5 + 5 + 6 + 2 
   奇数位 2 + 4 + 3 + 5 + 4 + 5

   步骤1:3+2+5+5+6+2=23 
   步骤2:23*3=69 
   步骤3:2+4+3+5+4+5=23 
   步骤4:69+23=92 
   步骤5:10-2=8 
   步骤6:校验码为 8


   数据码 校验码 
   代码位置序号 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 
   数字码 2 0 0 0 0 0 5 0 0 2 2 0 0 0 1 4 7 ? 
   偶数位 2 + 0 + 0 + 5 + 0 + 2 + 0 + 1 + 7 
   奇数位      0 + 0 + 0 + 0 + 2 + 0 + 0 + 4

   步骤1:2+0+0+5+0+2+0+1+7=17 
   步骤2:17*3=51 
   步骤3:0+0+0+0+2+0+0+4=6 
   步骤4:51+6=57 
   步骤5:10-7=3 
   步骤6:校验码为 3

  */ 
  

/// <summary>
  /// EAN码校验位的计算
  /// </summary>
  /// <param name="szCode"></param>
  /// <returns></returns>
  private bool GetVerifyBit(ref string szCode) 
  { 
   int nNum1 = 0; 
   int nNum2 = 0; 
   int nNum3 = 0; 
   int szLen = 0; 
   if ( szCode == null ) 
    return false;
   
   szLen = szCode.Length;     
   if(szLen <=12 || szLen >= 17) 
        return true; 
   for ( int i=0; i<szLen; i++) 
   {   

    if ( i%2 == 0 ) 
    {
     nNum2 += int.Parse(szCode[i].ToString()); //偶数     
    }
    else 
    {
     nNum1 += int.Parse(szCode[i].ToString()); //奇数     
    }
   } 
   nNum3 = (Operator.DiscountLabelBarLength % 2 ==0) ? nNum1 + nNum2 * 3 : nNum1 * 3 + nNum2 ; 
   
   int t ;
   if(nNum3%10>0) t= 10- (nNum3 % 10) ;
   else t=0;
   szCode+=t;

   return true
  }

    

/// <summary>
  /// EAN码校验位的计算
  /// </summary>
  /// <param name="szCode"></param>
  /// <returns></returns>
  private bool GetVerifyBit(ref string szCode) 
  { 
   int nNum1 = 0; 
   int nNum2 = 0; 
   int nNum3 = 0; 
   int szLen = 0; 
   if ( szCode == null ) 
    return false;
   
   szLen = szCode.Length;     
   if(szLen <=12 || szLen >= 17) 
        return true; 
   for ( int i=0; i<szLen; i++) 
   {   

    if ( i%2 == 0 ) 
    {
     nNum2 += int.Parse(szCode[i].ToString()); //偶数     
    }
    else 
    {
     nNum1 += int.Parse(szCode[i].ToString()); //奇数     
    }
   } 
   nNum3 = (Operator.DiscountLabelBarLength % 2 ==0) ? nNum1 + nNum2 * 3 : nNum1 * 3 + nNum2 ; 
   
   int t ;
   if(nNum3%10>0) t= 10- (nNum3 % 10) ;
   else t=0;
   szCode+=t;

   return true
  }

    

    

如果再精简些应该直接用数组类型来实现,这样就不用使用string了.代码中的细节部分不是效率最高写法.盖于本人学历尚浅,对char等类型掌握的还不熟.所以就用一堆的转型来解决了.

代码用c#写成,相信学java人士也能看懂吧 呵呵

前几天上传得代码有问题居然没人发现,汗,还是自己改过来吧...现在已经改完了,不知道会不会有其他得问题了,欢迎批评啊

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值