PLM 使用的UPC 是 14个数字组成的,兼容。
具体规则一:7位 + 5位 + 1 位 13位
算法分解:假设前面固定7位 为 0715799
中间5位0开始计算,每次产生一个新的UPC,需要加一
最后一位的产生规则如下。
* 071579917350 6 -> 0+1+7+9+7+5=29 7+5+9+1+3+0=25*3=75 29+75=104 10-4=6
* 071579917351 3 -> 0+1+7+9+7+5=29 7+5+9+1+3+1=26*3=78 29+78=107 10-7=3
* 071579917352 0 -> 0+1+7+9+7+5=29 7+5+9+1+3+2=27*3=81 29+81=110 10-0=10
* 071579917353 7 -> 0+1+7+9+7+5=29 7+5+9+1+3+3=28*3=84 29+84=113 10-3=7
* 071579917355 1 -> 0+1+7+9+7+5=29 7+5+9+1+3+5=30*3=90 29+90=119 10-9=1
* 071579917356 8 -> 0+1+7+9+7+5=29 7+5+9+1+3+6=31*3=93 29+93=122 10-2=8
* 071579917357 5 -> 0+1+7+9+7+5=29 7+5+9+1+3+7=32*3=96 29+96=125 10-5=5
* 071579917358 2 -> 0+1+7+9+7+5=29 7+5+9+1+3+8=33*3=99 29+99=128 10-8=2
* 071579917359 9 -> 0+1+7+9+7+5=29 7+5+9+1+3+9=34*3=102 29+102=131 10-1=9
* 071579917360 5 -> 0+1+7+9+7+6=30 7+5+9+1+3+0=25*3=75 30+75=105 10-5=5
* 071579917361 2 -> 0+1+7+9+7+6=30 7+5+9+1+3+1=26*3=78 30+78=108 10-8=2
* 071579917362 9 -> 0+1+7+9+7+6=30 7+5+9+1+3+2=27*3=81 30+81=111 10-1=9
public
static String calcolaCRC(String myCode) throws Exception {
String crc = "";
//
calcolo la somma delle cifre in pos pari e di quelle in pos dispari
int tot_pari = 0;
int tot_dispari = 0;
// i
caratteri in posizione pari sono in realta' in pos dispari e viceversa
// perche' quello che si definisce
PRIMO carattere e' in pos ZERO
for (int i = 0; i < myCode.length();
i++) {
if (i % 2 == 0) {
//
pos pari
tot_dispari += Integer.parseInt(myCode.substring(i, i + 1));
} else {
//
pos dispari
tot_pari += Integer.parseInt(myCode.substring(i, i + 1));
}
}
int tot = tot_dispari + 3 * tot_pari;
// del
totale mi serve solo l'ultima cifra
int i_crc = tot / 10;
i_crc = i_crc * 10;
i_crc = tot - i_crc;
crc = String.valueOf(10
- i_crc);
if (i_crc == 0) {
crc = "0";
}
return crc;
}
具体规则二:7位 + 4位 +1位 12位
07157991735 8
0*2 + 1*2 + (7*2-10+1)+ (9*2 -10 +1) + (7*2 -10 +1)+ (5*2 -10 +1) = 22
22%10 = 2
10-2 = 8
public static String calcolaOPCCRC(String OPC) throws Exception {
String crc = "";
int totSum = 0;
for (int i = 0; i < OPC.length(); i++) {
String curValue = OPC.substring(i, i + 1);
Integer intCurValue = new
Integer(curValue);
int parsedInt = intCurValue.intValue();
if (i % 2 == 0) {
parsedInt = parsedInt * 2;
if (parsedInt >= 10) {
parsedInt = parsedInt - 10 + 1;
}
}
totSum = totSum + parsedInt;
}
int
toSubtract = totSum % 10;
if (toSubtract == 0) {
toSubtract = 10;
}
int
crcInt = 10
- toSubtract;
crc
= new Integer(crcInt).toString();
return crc;
}
与UPC一致
//定义具体的导出的数据
定义处理改xml的xslt 程序
显示将要产生具体IDOC的数量 (目前来看,只有chrmas 有可能是2,其他都是1)
Chrmas
ßàZCHRMAS03
j3agrißàZJ3AGRI02
j3amatßàZ/AFS/MATMAS05
当前导出的物料,它的sku
属性有哪些。
物料属于不同的classification
的时候,它的characterstic
有所区别,
Z08属性 是说 某个classification
中的sku 属性。
Plm 中 有一个配置文件专门用来配置数据导出的配置项,其中就有此项配置。
数据结构为不规则的多叉树
PI 读取XML->根据transformation
定义决定产生哪些Idoc->读取xml里面所有的节点->根据对应的转换文件xslt进行转换->读取转换后文件的所有节点->做适配(mapping,一般不做什么事情)
将一个XML 转化成另外一种格式显示的语言
index.xml (utf-8格式编辑)
index.xsl (utf-8格式编辑)
合并:
Chrome 浏览器 安全等级太高,不能引用本地xsl,
需要在 dos 命令里面启动chrome 带上参数 --allow-file-access-from-files
可以直接访问XML节点的语言
解释是第几条idoc
总 Counter 为3 的情况
IDoc 0000001634665213
counter 为1
IDoc 0000001634665215
counter 为 2
IDoc 0000001634665216(出错)
counter 为3
总Counter
为4的情况
IDoc 0000001634644375
IDoc 0000001634644376
IDoc 0000001634644377
IDoc 0000001634644378
里面暂时只看到 D_X , 可能是语言/或者国家
但是它分为两种,一种BUSINESS 一种TEXT, TEXT 为何,不太清楚
001 material
Z06 size
Z07
color
Z08 sku
料号,物料组类型,工厂,采购类型
物料的相关属性
Size的相关属性
SKU 的相关属性
各种语言版本的描述信息
(grid
value 的详细信息,根节点无特别意义)
/AFS/E1MARM Grid value
E1MEANM Grid value 对应的UPC/STID
手机扫一扫
移动阅读更方便
你可能感兴趣的文章