enovia plm export to sap
阅读原文时间:2023年07月11日阅读:1

UPC 结构

PLM 使用的UPC 是 14个数字组成的,兼容。

  1. 前两位为 0,后12位为有效数字,在SAP中0会被忽略,符合国际UPC通用 规则,

  1. 前一位为0,后13 位为有效数字,符合EAN规则

UPC 产生规则

具体规则一: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一致

总体结构:

//定义了一些很重要和系统集成有关的参数

//定义具体的导出的数据

重要标签解释:

Transformation

Z_MD_23_XSLT

定义处理改xml的xslt 程序

sapSerialization

1

1

1

显示将要产生具体IDOC的数量 (目前来看,只有chrmas 有可能是2,其他都是1)

Chrmas
ßàZCHRMAS03

j3agrißàZJ3AGRI02

j3amatßàZ/AFS/MATMAS05

listZ08Chars

当前导出的物料,它的sku
属性有哪些。

物料属于不同的classification
的时候,它的characterstic
有所区别,

Z08属性 是说 某个classification
中的sku 属性。

Plm 中 有一个配置文件专门用来配置数据导出的配置项,其中就有此项配置。

object :

数据结构为不规则的多叉树

转换过程: (邀请PI协助一下)

PI 读取XML->根据transformation
定义决定产生哪些Idoc->读取xml里面所有的节点->根据对应的转换文件xslt进行转换->读取转换后文件的所有节点->做适配(mapping,一般不做什么事情)

XslT语言

将一个XML 转化成另外一种格式显示的语言

例子:将一个XML 转换成网页可以显示

index.xml    (utf-8格式编辑)

西游记

吴承恩

红楼梦

曹雪芹

index.xsl (utf-8格式编辑)

My CD Collection

合并:

Chrome 浏览器 安全等级太高,不能引用本地xsl,

需要在 dos 命令里面启动chrome 带上参数  --allow-file-access-from-files

XPath语言

可以直接访问XML节点的语言

ZSSD_KSERIAL

解释是第几条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

ZMM_CLASSIFICATION_HEADER

里面暂时只看到 D_X , 可能是语言/或者国家

但是它分为两种,一种BUSINESS 一种TEXT, TEXT 为何,不太清楚

001  material

Z06 size

Z07
color

Z08 sku

ZSMMA_PLM_TRANSIT

料号,物料组类型,工厂,采购类型

E1MARA1

物料的相关属性

Size的相关属性

SKU 的相关属性

E1J3MRA

E1MAKTM

各种语言版本的描述信息

E1MARMM

(grid
value 的详细信息,根节点无特别意义)

/AFS/E1MARM   Grid value

E1MEANM      Grid value 对应的UPC/STID