我的应用程序目前在java上,我发送一个LinkedHashMap(从Excel获取数据)到服务。现在我将我的应用程序转换为php。
我需要在php中创建一个LinkedHashMap。
String data[][]; // Excel data in the form of 2-D Array.
LinkedHashMap<Integer, ArrayList> mapToSend = null;
mapToSend = new LinkedHashMap<Integer, ArrayList>();
for (int i = 0; i < data[0].length; i++) {
ArrayList<String> ar = new ArrayList<String>();
for (int j = 0; j < numberOfRecords; j++) {
if (data[j][i] != null) {
data[j][i] = data[j][i].toString();
ar.add(data[j][i]); // Add in array through coloumnwise
} else {
ar.add("Empty");
}
}
mapToSend.put(i, ar); // making a map like {0=[coloumn data1],1=[coloumn data2]....}
}
这就是我创建发送到我服务的地图的方式。
我正在使用PHPExcel从Excel中读取数据。
我需要创建一个地图并将其发送给服务。请建议。
答案 0 :(得分:1)
您提供的代码实际上看起来更像是一个正常的代码&#39; PHP中的数组。 PHP中的数组可以用作更传统意义上的数组,映射就像你的Java (除了它们仍然拥有超过密钥本身隐含的顺序)。< / p>
您的实现在PHP中如下所示。有关于数据输入和所需业务逻辑的许多假设,我会写一些测试用例来定义诸如“真实”,“0”,“等”的情况。反对所需的输出。基本上,请注意strval($data[$j][$i])
可能表现不同的所有方式。
您正在从整数=&gt;创建地图Java中的字符串,但对我来说它看起来就像一个普通的数组。
$data = array();
//the input data
$data[] = array("val1", "val2");
$data[] = array("val3", 0);
$data[] = array("val4");
$data[] = array("val5", "");
$data[] = array(0, "val6");
$numberOfRecords = count($data); //assuming all of it...
$mapToSend = array();
for($i = 0; $i < count($data[0]); $i++) {
$ar = array();
for($j = 0; $j < $numberOfRecords; $j++) {
if( ($val = strval($data[$j][$i])) != "" ) {//the comparison of your choice, depending on the logic/input
$ar[] = $val;
} else {
$ar[] = "Empty";
}
}
$mapToSend[] = $ar; //naturally, this will have indexes 0, 1, 2...
}
var_dump( $mapToSend );
输出:
array(2) {
[0]=>
array(5) {
[0]=>
string(4) "val1"
[1]=>
string(4) "val3"
[2]=>
string(4) "val4"
[3]=>
string(4) "val5"
[4]=>
string(1) "0"
}
[1]=>
array(5) {
[0]=>
string(4) "val2"
[1]=>
string(1) "0"
[2]=>
string(5) "Empty"
[3]=>
string(5) "Empty"
[4]=>
string(4) "val6"
}
}