我正在尝试使用PHP将CSV文件(类型:application / vnd.ms-excel)上传到我的Unix框中。然后将其FTP到Mainframes。
在每行末尾添加额外空行添加到上传文件时会出现问题,我可以在cmd提示符下使用ftp命令下载上传的CSV文件时看到此信息。
在Unix框中查看时,CSV中不显示多余的行。
当它将它FTP到大型机时,我可以看到每行添加一个点。 Hex Dec 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";
}
?>
答案 0 :(得分:0)
您可能需要查看http://at2.php.net/manual/en/function.trim.php方法。
您可以在存储后打开文件,遍历每一行并trim()
。您可以将它们打印回文件(或者只是加载所有内容,迭代并执行file_put_contents()
)。这应该在您上传之前从开头和结尾删除任何空格。
如果您只想将其从最后删除,您也可以使用rtrim()
,或者如果您想要更灵活,可以使用preg_replace()
和/\s*$/
之类的内容。