我正在寻找如何使用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);
}
}