EAN码校验位的计算方法

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

/**

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

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航