0

PHP を使用して CSV ファイル (type:application/vnd.ms-excel) を Unix ボックスにアップロードしようとしています。そして、それをメインフレームに FTP します。

各行の最後に余分な空白行がアップロードされたファイルに追加されると、アップロード時に問題が発生します。cmd プロンプトで ftp コマンドを使用してアップロードされた CSV ファイルをダウンロードすると、これを確認できます。

Unix ボックスで表示しているときに、CSV に余分な行が表示されません。

メインフレームに FTP 送信すると、各行にドットが追加されているのがわかります。16 進数 10 進数 x'0D'

アップロード中にこの余分な文字を切り捨てるのを手伝ってくれませんか?

私のHTMLファイル

<html>
<body>
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<br />
<input type="submit" name="submit" value="Submit" />
</form>
</body>
</html>

私のPHPコード「upload_file.php」

<?php
$allowedExts = array("csv", "CSV");
$extension = end(explode(".", $_FILES["file"]["name"]));
if (($_FILES["file"]["type"] == "application/vnd.ms-excel")
&& in_array($extension, $allowedExts))
  {
  if ($_FILES["file"]["error"] > 0)
    {
    echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
    }
  else
    {
    echo "Upload: " . $_FILES["file"]["name"] . "<br />";
    echo "Type: " . $_FILES["file"]["type"] . "<br />";
    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
    if (file_exists("upload/" . $_FILES["file"]["name"]))
      {
      echo $_FILES["file"]["name"] . " already exists. ";
      }
    else
      {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      $conn = ftp_connect("a.b.c.com") or die("Could not connect");
      ftp_login($conn,"login","pass");
      echo ftp_put($conn,"'dataset.name'","upload/" . $_FILES["file"]["name"],FTP_ASCII);
      ftp_close($conn);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
      }
    }
  }
else
  {
  echo "Invalid file";
  }
?>
4

1 に答える 1

0

http://at2.php.net/manual/en/function.trim.phpメソッドを参照してください。

ファイルを保存した後、各行とtrim()それらを反復してファイルを開くことができます。それらをファイルに出力できます(または、すべてをロードして iterante を実行しますfile_put_contents())。これにより、アップロードする前に最初と最後から空白が削除されます。

最後から削除したいだけの場合は、rtrim()または を使用することもできます。より柔軟にしたい場合は、 などで行うことができpreg_replace()ます/\s*$/

于 2012-08-02T10:27:47.360 に答える