从领星ERP到金蝶云星空:一步步实现数据转换与写入

  • 轻易云集成顾问-彭亮

领星ERP数据集成金蝶云星空案例:高效处理发货结算报告并生成销售出库单

在企业信息管理系统的对接和集成过程中,如何实现数据的无缝流动、准确记录和高效分析,是每个技术人员面临的重要课题。本文将深入探讨如何通过API接口有效地将领星ERP中的发货结算报告数据集成到金蝶云星空系统中,并生成销售出库单,特别是针对日本站点的数据处理。

案例背景和挑战

该案例主要集中于以下几个核心问题:

  1. 快速写入大量数据:确保来自领星ERP的数据能够以高吞吐量方式及时写入到金蝶云星空中,以保障业务流程的时效性。
  2. 实时监控与异常检测:供应链环节需要对数据状态进行实时监控,同时设置告警机制来捕捉并解决可能出现的问题。
  3. API资产管理与优化配置:借助统一视图掌握API使用情况,实现资源优化配置,提高系统整体效率。
  4. 自定义转换逻辑及格式差异处理:两个系统间的数据结构存在显著差异,通过定制化逻辑实现平滑转换。

技术方案概述

首先,我们利用平台提供的可视化工具设计了一个直观且易于管理的数据流,从抓取开始直到最终写入。在此过程中,我们调用了领星ERP中的/cost/center/api/settlement/report接口来获取发货结算报告,并采用分页策略应对大规模数据请求。

此外,通过批量集成功能,高效率地完成了多条记录的一次性传输,避免重复劳动及潜在错误。在向金蝶云星空进行写入操作时,调用其batchSave API接口,将处理后的JSON结构体注入其数据库中。值得强调的是,为了保证不会漏掉任何一笔交易,我们加入了一些列校验步骤,并搭建重试机制,应对突发网络或服务器故障引起的问题。

下一步内容具体实施细节包括各个API参数设定、限流策略应用以及自定义映射规则等技术要点。这使得整个过程不仅透明而且高效安全,为企业提供强有力的信息支持。 用友与MES系统接口开发配置

调用领星ERP接口/cost/center/api/settlement/report获取并加工数据

在轻易云数据集成平台的生命周期中,调用源系统接口是至关重要的一步。本文将深入探讨如何通过调用领星ERP的接口/cost/center/api/settlement/report来获取发货结算报告,并对数据进行初步加工。

接口配置与请求参数

首先,我们需要了解该接口的元数据配置。根据提供的元数据,接口的请求方式为POST,主要用于查询(effect: QUERY)。以下是请求参数的详细配置:

  • amazonSellerIds: 亚马逊店铺id,类型为字符串,通过解析器StringToArray将其转换为数组。
  • sids: 店铺id,类型为字符串,同样通过StringToArray解析器转换。
  • timeType: 时间类型,固定值为"03"。
  • filterBeginDate: 开始日期,通过函数DATE(SUBDATE(NOW(), 14))计算,即当前日期前14天。
  • filterEndDate: 结束日期,通过函数DATE(SUBDATE(NOW(), 6))计算,即当前日期前6天。
  • offset: 分页偏移量,类型为字符串。
  • length: 分页长度,固定值为100。

这些参数确保了我们能够准确地获取所需的数据,并且支持分页功能,以便处理大量数据时能够分批次获取。

请求示例

基于上述配置,一个典型的请求体可能如下所示:

{
  "amazonSellerIds": ["A220ISOUK310XV"],
  "sids": ["7207"],
  "timeType": "03",
  "filterBeginDate": "2023-09-01",
  "filterEndDate": "2023-09-09",
  "offset": "0",
  "length": "100"
}

在这个请求体中,我们使用了固定值和动态计算的日期范围来获取最近一段时间内的发货结算报告。

数据清洗与加工

在接收到响应数据后,我们需要对其进行清洗和初步加工。轻易云平台提供了自动填充响应(autoFillResponse)的功能,这意味着我们可以直接利用响应中的字段进行后续处理。

假设响应数据如下:

{
  "data": [
    {
      "shipmentId": "12345",
      "shipmentItemId": "67890",
      "amazonOrderId": "A1B2C3D4E5",
      "sellerName": "星旅-JP",
      ...
    },
    ...
  ]
}

我们可以根据条件过滤掉不符合要求的数据。例如,根据元数据中的条件配置(condition_bk),我们需要排除sellerName等于"星旅-JP"的数据:

filtered_data = [item for item in response['data'] if item['sellerName'] != '星旅-JP']

数据转换与写入

经过清洗后的数据需要进行格式转换,以便写入目标系统。在本案例中,我们需要将其转换为金蝶云星空系统所需的销售出库单格式。假设目标格式如下:

{
  "orderId": "{amazonOrderId}",
  "shipmentDetails": [
    {
      "shipmentId": "{shipmentId}",
      "itemId": "{shipmentItemId}"
    }
  ],
  ...
}

通过简单的数据映射,可以实现这一转换:

transformed_data = [
    {
        "orderId": item["amazonOrderId"],
        "shipmentDetails": [
            {
                "shipmentId": item["shipmentId"],
                "itemId": item["shipmentItemId"]
            }
        ]
    }
    for item in filtered_data
]

最后,将转换后的数据写入目标系统即可完成整个集成过程。

总结

通过以上步骤,我们成功调用了领星ERP接口获取发货结算报告,并对数据进行了清洗和初步加工。利用轻易云平台提供的自动化工具和灵活的配置选项,可以高效地完成从源系统到目标系统的数据集成任务。这不仅提高了业务透明度和效率,也确保了数据处理过程中的准确性和可靠性。 钉钉与CRM系统接口开发配置

轻易云数据集成平台生命周期第二步:ETL转换与数据写入金蝶云星空API接口

在数据集成过程中,ETL(提取、转换、加载)是关键步骤之一。本文将详细探讨如何利用轻易云数据集成平台,将源平台的发货结算报告数据转换为金蝶云星空API接口所能接收的格式,并最终写入目标平台。

数据请求与清洗

首先,从源平台获取发货结算报告数据。这一步涉及到对原始数据的清洗和标准化处理,确保数据质量和一致性。我们假设这一步已经完成,接下来进入ETL过程中的转换与加载阶段。

数据转换与写入

在轻易云数据集成平台中,我们需要配置元数据以实现将清洗后的源数据转换为金蝶云星空API接口可接受的格式。以下是具体的元数据配置及其解释:

{
    "api": "batchSave",
    "effect": "EXECUTE",
    "method": "POST",
    "idCheck": true,
    "operation": {
        "method": "merge",
        "field": "amazonOrderId,sellerName,shipmentsDateLocale",
        "bodySum": ["quantity", "itemPrice"],
        "bodyName": "details",
        "header": ["amazonOrderId", "sellerName", "shipmentsDateLocale", "currencyCode"],
        "body": ["localSku", "quantity", "itemPrice", "itemTax", "processingStatus", "brandName"]
    },
    ...
}
API接口配置
  • api: 指定调用的API接口名称,这里为batchSave
  • effect: 设置为EXECUTE,表示执行操作。
  • method: HTTP请求方法,这里使用POST
  • idCheck: 设置为true,表示需要进行ID检查。
操作配置
  • method: 操作方法,这里使用merge,表示合并操作。
  • field: 指定用于合并操作的字段,这里包括amazonOrderId, sellerName, shipmentsDateLocale
  • bodySum: 指定需要汇总的字段,这里包括quantity, itemPrice
  • bodyName: 明细信息的名称,这里为details
  • header: 表头字段列表,包括amazonOrderId, sellerName, shipmentsDateLocale, currencyCode
  • body: 明细字段列表,包括localSku, quantity, itemPrice, itemTax, processingStatus, brandName
请求字段配置
[
    {"field":"FBillTypeID","label":"单据类型","type":"string","describe":"单据类型","parser":{"name":"ConvertObjectParser","params":"FNumber"},"value":"XSCKD01_SYS"},
    {"field":"FBillNo","label":"单据编号","type":"string","describe":"单据编号"},
    {"field":"FDate","label":"日期","type":"string","describe":"日期","value":"{{shipmentsDateLocale|datetime}}"},
    ...
]
  • FBillTypeID: 单据类型,通过解析器将值转换为金蝶系统识别的编码。
  • FBillNo: 单据编号,通常由系统自动生成或由外部传入。
  • FDate: 日期字段,通过模板引擎将源数据中的日期格式化为目标系统所需格式。
子实体配置
{
    ...
    {"field":"SubHeadEntity","label":"财务信息","type":"object","children":[
        {"field":"FSettleOrgID","label":"结算组织","type":"string","value":"105","parser":{"name":"ConvertObjectParser","params":"FNumber"}},
        {"field":"FSettleCurrID","label":"结算币别","type":"string","value":"_findCollection find FNumber from 15a9bbe3-9421-3c17-9083-98da2a5f6cc6 where FCODE={currencyCode}"},
        ...
    ]}
}

子实体部分主要包含财务信息和明细信息:

  • 财务信息包括结算组织、结算币别等,通过解析器将值转换为目标系统识别的编码或通过查找表进行匹配。
明细信息配置
{
    ...
    {"field":"FEntity","label":"明细信息","type":"array","describe":"明细信息","value":"details","children":[
        {"field":"FMaterialID","label":"物料编码","type":"string","describe":"基础资料","parser":{"name":"ConvertObjectParser","params":"FNumber"},"value":"_findCollection find FNumber from 38049d14-52b6-3935-9504-bf60a0c3a5ff where FSpecification={{details.localSku}}"},
        {"field":"FRealQty","label":"实发数量","type":"string","describe":"数量","value":"{{details.quantity}}"},
        ...
    ]}
}

明细信息部分包括物料编码、实发数量等:

  • 物料编码通过解析器从查找表中匹配对应的编码。
其他请求参数
[
    {"field": "FormId", "label": "业务对象表单Id", "type": "string", "describe": "必须填写金蝶的表单ID如:PUR_PurchaseOrder", "value": "SAL_OUTSTOCK"},
    {"field": "Operation", "label": "执行的操作", "type": "string", "describe": "", value="Save"},
    ...
]

其他请求参数包括业务对象表单ID、执行操作类型等:

  • 表单ID指定目标系统中的业务对象,如销售出库单(SAL_OUTSTOCK)。

通过上述元数据配置,我们可以实现从源平台到金蝶云星空API接口的数据转换和写入。这一过程确保了不同系统间的数据无缝对接,并提高了业务处理效率。 金蝶与MES系统接口开发配置