首页 > 解决方案 > 制表符分隔的 PHP 字符串到数组

问题描述

我正在使用 GitHub 上的 AmazonMwsComplete 存储库向 Amazon 的 AWS API 发出请求,特别是 GetReport 调用。我从我的请求中得到了积极的回应,所以一切似乎都很好,唯一的问题是它似乎将 XML 响应转换为一个制表符分隔的字符串,我无法弄清楚如何正确格式化为一个 PHP 数组。

本质上,响应看起来像这样:

string(52148) "sku     asin    price   quantity       Business Price Quantity Price Type        Quantity Lower Bound 1 Quantity Price 1       Quantity Lower Bound 2 Quantity Price 2 Quantity Lower Bound 3 Quantity Price 3       Quantity Lower Bound 4 Quantity Price 4 Quantity Lower Bound 5 Quantity Price 5       ProductTaxCode VatExclusivePrice        VatExclusiveBusinessPrice      VatExclusiveQuantityPrice1        VatExclusiveQuantityPrice2     VatExclusiveQuantityPrice3        VatExclusiveQuantityPrice4     VatExclusiveQuantityPrice5
XX-XXXX-XXXX   XXXXXXXXXX     0.01   1                                                                                                                                                        
XX-XXXX-XXX   XXXXXXXXXX     0.01    1                                                                                                                                                       
XXX-XXX-XXX    XXXXXXXXXX     0.01   1“

当我将其转换为数组时,它看起来像这样:

array(22702) {
  [0]=>
  string(3) "sku"
  [1]=>
  string(4) "asin"
  [2]=>
  string(5) "price"
  [3]=>
  string(8) "quantity"
  [4]=>
  string(14) "Business Price"
  [5]=>
  string(19) "Quantity Price Type"
  [6]=>
  string(22) "Quantity Lower Bound 1"
  [7]=>
  string(16) "Quantity Price 1"
  [8]=>
  string(22) "Quantity Lower Bound 2"
  [9]=>
  string(16) "Quantity Price 2"
  [10]=>
  string(22) "Quantity Lower Bound 3"
  [11]=>
  string(16) "Quantity Price 3"
  [12]=>
  string(22) "Quantity Lower Bound 4"
  [13]=>
  string(16) "Quantity Price 4"
  [14]=>
  string(22) "Quantity Lower Bound 5"
  [15]=>
  string(16) "Quantity Price 5"
  [16]=>
  string(14) "ProductTaxCode"
  [17]=>
  string(17) "VatExclusivePrice"
  [18]=>
  string(25) "VatExclusiveBusinessPrice"
  [19]=>
  string(26) "VatExclusiveQuantityPrice1"
  [20]=>
  string(26) "VatExclusiveQuantityPrice2"
  [21]=>
  string(26) "VatExclusiveQuantityPrice3"
  [22]=>
  string(26) "VatExclusiveQuantityPrice4"
  [23]=>
  string(40) "VatExclusiveQuantityPrice5
XX-XXXX-XXXX"
  [24]=>
  string(10) "XXXXXXXXX"
  [25]=>
  string(5) "0.01"
  [26]=>
  string(1) "1"
  [27]=>
  string(0) ""
  [28]=>
  string(0) ""
  [29]=>
  string(0) ""
  [30]=>
  string(0) ""
}

这有一些问题,“VatExclusiveQuantityPrice5”标题与产品 SKU 的第一条信息混合在一起,因此它位于数组中的同一元素中。

制表符分隔的字符串还使用 20 个制表符作为“换行”分隔符,因此我在下一条信息之前的数组中有 20 个空白元素。

我对此有一个可能的解决方案,涉及将其转换为文本文件并直接导入数据库,但肯定必须有一种简单的方法将其转换为 PHP 数组,数据库选项似乎是一种更困难的方法处理这些信息。

标签: phparraysamazon-web-servicesaws-sdkcsv

解决方案


$myArray = [];
$lines = explode(PHP_EOL, $myText);
$l = 0;
foreach($lines as $line) {
    $myArray[$l] = explode("\t", $line);
    $l++;
}

PHP_EOL:新行分隔符之一,“\n”、“\r”或“\n\r”

"\t": 'tab' 字符,带有双引号,以便 PHP 可以将其解释为特殊字符而不仅仅是字符串 \t

第一行将是您的标题,接下来是表格内容。


推荐阅读