/**
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人士也能看懂吧 呵呵
前几天上传得代码有问题居然没人发现,汗,还是自己改过来吧...现在已经改完了,不知道会不会有其他得问题了,欢迎批评啊