PHP上传CSV文件Extra Carraige返回


PHP Upload CSV file Extra Carraige Return

我正在尝试使用PHP将CSV文件(类型:application/vnd.ms-excel)上传到我的Unix盒子中。然后将其FTP到主机。

当在每行末尾向上传的文件添加额外的空行时,上传时会出现问题,当我在cmd提示符下使用ftp命令下载上传的CSV文件时,我可以看到这一点。

在Unix框中查看时,CSV中不会显示任何额外的行。

当它将其FTP到大型机时,我可以看到每行都添加了一个点。十六进制十进制x'D'

你能帮我在上传时删掉这个多余的字符吗?

我的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";
  }
?>

您可能需要查看http://at2.php.net/manual/en/function.trim.php方法

您可以在存储文件后打开该文件,在每一行上迭代并trim()它们。您可以将它们打印回文件(或者只加载所有内容,迭代并执行file_put_contents())。这应该会在上传之前删除开头和结尾的任何空白

如果你只是想把它从最后删除,你也可以使用rtrim(),或者如果你想更灵活,你可以用preg_replace()和类似/'s*$/的东西来做。