CSV 형식으로 내보내려고합니다.하지만 사용하는 상호 호스트가 mysql에서 FILE 함수를 비활성화했습니다.MYSQL FILE 함수없이 CSV 내보내기
간단한 SELECT를 한 다음 PHP로 fopen 및 fwrite를 수행했습니다.
문제는 필드에 캐리지 리턴이나 큰 따옴표가 있다는 것입니다.
어떻게 유지하고 올바른 CSV 파일을 만드시겠습니까?
고마워요.
CSV 형식으로 내보내려고합니다.하지만 사용하는 상호 호스트가 mysql에서 FILE 함수를 비활성화했습니다.MYSQL FILE 함수없이 CSV 내보내기
간단한 SELECT를 한 다음 PHP로 fopen 및 fwrite를 수행했습니다.
문제는 필드에 캐리지 리턴이나 큰 따옴표가 있다는 것입니다.
어떻게 유지하고 올바른 CSV 파일을 만드시겠습니까?
고마워요.
. 당신은 다음과 같은 방법으로 할 수 있습니다. 당신이 html 코드를 가지고 설명을 동봉 만든다 +, 당신은 큰 따옴표를 사용해야합니다
$filename ='data.csv';
$csv_terminated = "\n";
$csv_separator = ",";
$csv_enclosed = '"';
$csv_escaped = "\\";
$results = array('1','2','3');// value
$schema_insert = '';
$header = array('a','b','c');// header
for ($i = 0; $i< count($header); $i++)
{
$l = $csv_enclosed . str_replace($csv_enclosed, $csv_escaped . $csv_enclosed,
stripslashes($header[$i])) . $csv_enclosed;
$schema_insert .= $l;
$schema_insert .= $csv_separator;
} // end for
$out = trim(substr($schema_insert, 0, -1));
$out .= $csv_terminated;
// Format the data
for($i=0;$i<count($results);$i++)
{
$row = $results[$i];
$schema_insert = '';
for ($j = 0; $j < count($header); $j++)
{
if ($row[$j] == '0' || $row[$j] != '')
{
if ($csv_enclosed == '')
{
$schema_insert .= $row[$j];
} else
{
$schema_insert .= $csv_enclosed .
str_replace($csv_enclosed, $csv_escaped . $csv_enclosed, $row[$j]) . $csv_enclosed;
}
} else
{
$schema_insert .= 'NULL';
}
if ($j < count($header) - 1)
{
$schema_insert .= $csv_separator;
}
} // end for
$out .= $schema_insert;
$out .= $csv_terminated;
} // end while
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Length: " . strlen($out));
// Output to browser with appropriate mime type, you choose <img src="http://thetechnofreak.com/wp-includes/images/smilies/icon_wink.gif" alt=";)" class="wp-smiley">
header("Content-type: text/x-csv");
//header("Content-type: text/csv");
//header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=$filename");
echo $out;
알 수 있습니다. + 빈 값 -> Null 텍스트 또는 0 값으로 변경
CSV가 향상됩니다.
안녕하세요. "스팸"으로 응답에 태그를 지정하지 마십시오. 그것은 싫은 내색이다. 이 주제에 관해서도 [이 게시물] (http://meta.stackexchange.com/questions/5029/are-taglines-signatures-disallowed)을 읽으십시오. 여기에 더 머물 수 있습니다. – PeeHaa
당신은 예를 들어, 사용 헤더() 헤더 기능 후 원하는
출력 모든 (CSV 형식에 대한 기본)에 의해 file.csv 다운로드 할 수 있습니다 최고의 CSV를 구축하기 위해
$filename = "output";
header('Content-Type: text/csv');
header('Content-disposition: attachment;'.$filename.'=.csv');
$separate = ","; //or ;
$endline = "\r\n";
foreach($data as $key => $item)
{
echo $key.$separate.$value.$endline;
}
protected function getCsv($fileName, array $data)
{
// alot of headers here, make force download work on IE8 over SSL
header("Pragma: public");
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Cache-Control: private",false);
header("Content-Type: application/octet-stream");
header('Content-Disposition: attachment; filename="'.$fileName.'"');
header("Content-Transfer-Encoding: binary");
// Joe Green says:
// based on http://www.php.net/manual/en/function.fputcsv.php#100033
$outStream = fopen("php://output", "r+");
function __getCsv(&$vals, $key, $filehandler) {
fputcsv($filehandler, $vals, ',', '"');
}
array_walk($data, '__getCsv', $outStream);
fclose($outStream);
}
fputcsv은 (는) 친구입니다. 또한,이 시점까지이 기능을 수정해야했습니다. 이러한 헤더 중 일부는 IE에서 csv를 CSV, 특히 SSL을 통해 강제로 열도록 요구합니다. 나는 IE8이 첫 번째 인스턴스에서 'text/csv'콘텐츠 유형을 인식하지 못하고 두 번째 인스턴스에서 SSL 다운로드와 관련된 일부 보안 기능을 인식하지 못한다는 것을 상기 한 것 같습니다.
호스트가 비활성화하지 않은 경우 'fputcsv' 기능이 있습니다. - http://php.net/manual/en/function.fputcsv.php – andrewsi