将 HTML 表单 Claumn 数组转换为行 PHP


convert html form cloumn array to row php

我有一个html表单,它有多个文本区域,其值来自数据库。

while($row=mysql_fetch_array($record)){
echo "<tr class='item-row'>";
echo "<td>" .$startSrno. "</td>";
echo "<td class='item-name'> <div class='delete-wpr'><textarea name='productName[]'>".$row['name']."</textarea></div></td>";
echo "<td>".$row['pkgsize']."</td>";
echo "<td><textarea class='savings' name='saving[]'>".$row['savings']."</textarea></td>";
echo "<td><textarea class='mrp' name='mrp[]'>".$row['MRP']."</textarea></td>";
echo "<td><textarea class='qty' name='qty[]'>1</textarea></td>";
echo "<td><textarea class='cost' name='saleprice[]'>".$row['saleprice']."</textarea></td>";
echo "<td><textarea class='price' name='total[]'>".$row['saleprice'] * '1'."</textarea></td>";
echo '<input type="hidden" name="productId[]" value="'.$row['id']. '">';
echo '<input type="hidden" name="pkgsize[]" value="'.$row['pkgsize']. '">';
echo "</tr>";
$startSrno++;
}

现在,当我提交此表单时,我得到了这些具有多个值的表单数组,但它们是列格式,而我需要以行形式存在:

通过这样做(使用内爆函数 ()),我得到以下输出:

$id = implode(',',$_POST['productId']);<br/>
$name = implode(',',$_POST['productName']);
$saving = implode(',',$_POST['saving']);
$qty = implode(',',$_POST['qty']);
$pkgsize = implode(',',$_POST['pkgsize']);
$mrp = implode(',',$_POST['mrp']);
$saleprice = implode(',',$_POST['saleprice']);
$total = implode(',',$_POST['total']);

使用回波输出电流,例如回声$name==(升压,Olay):

Boost,Olay,Bournvita (Name)
45,35,20 (Savings)
2,3,5 (qty)
500gm,20ml,1kg(pkgsize)
120,70,320(mrp)
75,35,300(saleprice)
150,105,1500(total)

但是我希望以下所述(行)格式的输出直接在插入查询中使用:

(Boost,45,2,500gm,120,75,150),(Olay,35,3,20ml,120,35,105),(Bournvita,20,5,1kg,300,75,1500)

提前致谢

听起来你需要一个 for 循环。前提是您已经验证了该数据并确保没有传入空的"单元格"。

$products = '(' . $name[0] .  ',' . $saving[0] . ',' . $qty[0] . ',' . $pkgsize[0] . ',' . $mrp[0] . ',' . $saleprice[0] . ',' . $total[0] . ')';
for($i = 1; $i < count($id); $i++)
    $products = ',(' . $name[i] .  ',' . $saving[i] . ',' . $qty[i] . ',' . $pkgsize[i] . ',' . $mrp[i] . ',' . $saleprice[i] . ',' . $total[i] . ')';

我的PHP技能可能不是最新的,它可能会做得更好,但我会说这应该有效。

$b = '';
for ($i=0; $i<count($_POST['productId']); $i++) {
  $a = array(
   //$_POST['productId'][$i],
   $_POST['productName'][$i],
   $_POST['saving'][$i],
   $_POST['qty'][$i],
   $_POST['pkgsize'][$i],
   $_POST['mrp'][$i],
   $_POST['saleprice'][$i],
   $_POST['total'][$i]
  );
  if ($b != '') $b .= ',';
  $b = '('.implode(',',$a).')';
}
echo $b;

感谢 Gravirel 的帮助,终于用一点或反复试验做到了。

$oddArray = array();
$evenArray = array();
$insertValues = '';
for ($i=0; $i<count($_POST['productId']); $i++) {
  if ($i % 2 == 0) {
      //echo $i."<br/>";
      $insertValues .= '(';
      $evenArray = array(
       //$_POST['productId'][$i],
       ''''.$_POST['productName'][$i].'''',
       $_POST['saving'][$i],
       $_POST['qty'][$i],
       ''''.$_POST['pkgsize'][$i].'''',
       $_POST['mrp'][$i],
       $_POST['saleprice'][$i],
       $_POST['total'][$i]
      );
      $insertValues .= implode(',',$evenArray);
      $insertValues .= '),';
  }else{
      //echo $i."<br/>";
      $insertValues .= '(';
      $oddArray = array(
       //$_POST['productId'][$i],
       ''''.$_POST['productName'][$i].'''',
       $_POST['saving'][$i],
       $_POST['qty'][$i],
       ''''.$_POST['pkgsize'][$i].'''',
       $_POST['mrp'][$i],
       $_POST['saleprice'][$i],
       $_POST['total'][$i]
      );
      $insertValues .= implode(',',$oddArray);
      $insertValues .= '),';
  }
 }
$insertValuesTrim = rtrim($insertValues,',');
输出 : ("提升",45,2,"500克",120,75,150),("奥莱",35,3,"20毫升",120,35,105

),("Bournvita",20,5,"1公斤",300,75,1500)