1

我正在寻找如何使用C# 客户端库或任何其他客户端库,或使用亚马逊 MWS Scratchpad查询未记录的 MWS API 以获取库存调节报告(卖方中央履行报告的 API 名称列表) - 后者是设置值的规则字段 MarketplaceIdList.Id.1、StartDate、EndDate 和 ReportOptions 对我来说不清楚:我正在设置前三个字段,就像我通常为其他报告类型所做的那样,我将 ReportOptions 字段留空 - 并且通过 MWS API 调用_GET_FBA_RECONCILIATION_REPORT_DATA_ 报告的 C# 库已被接受,但最终获得“无可用数据”状态。

更新

通过 Sellercentral.amazon.com 网站手动请求下载的示例解决方法代码_GET_FBA_RECONCILIATION_REPORT_DATA_使用 MWS API C# 客户端库的最新报告:

    //private string ACCESS_KEY_ID => ...
    //private string SECRET_ACCESS_KEY =>  ...
    //private string MERCHANT_ID => ...
    //private string MAKETPLACE_ID => ...
    //private string APPLICATION_NAME => ...
    //private string APPLICATION_VERSION => ...
    public void DownloadMostRecentFBAInventoryReconciliationReport(string downloadedReportFullPath)
    {
        string reportId = "";
        string reportType = "_GET_FBA_RECONCILIATION_REPORT_DATA_";

        var config = new MarketplaceWebService.MarketplaceWebServiceConfig();
        config.ServiceURL = "https://mws.amazonservices.com";
        config.SetUserAgentHeader(APPLICATION_NAME, APPLICATION_VERSION, "C#");
        var service = new MarketplaceWebService.MarketplaceWebServiceClient(ACCESS_KEY_ID, SECRET_ACCESS_KEY, config);

        // find most recent report id for '_GET_FBA_RECONCILIATION_REPORT_DATA_' report type
        {
            var request = new MarketplaceWebService.Model.GetReportRequestListRequest();
            request.Merchant = MERCHANT_ID;
            request.ReportTypeList = new MarketplaceWebService.Model.TypeList();
            request.ReportTypeList.Type.Add(reportType);

            var response = service.GetReportRequestList(request);
            foreach (MarketplaceWebService.Model.ReportRequestInfo info in response.GetReportRequestListResult.ReportRequestInfo)
            {
                if (!info.ReportProcessingStatus.Equals("_DONE_")) continue;
                reportId = info.GeneratedReportId;
                break;
            }
        }

        // if most recent reportId found - download report's (.csv) data file into {{ downloadedReportFullPath }}
        if (!string.IsNullOrEmpty(reportId))
        {
            var request = new MarketplaceWebService.Model.GetReportRequest();
            request.Merchant = MERCHANT_ID;
            request.ReportId = reportId;
            request.Report = File.Open(downloadedReportFullPath, FileMode.OpenOrCreate, FileAccess.ReadWrite);
            var response = service.GetReport(request);
        }
    }
4

0 回答 0