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人士也能看懂吧 呵呵

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值