[ php ] PHP에서 CSV 로 내보내기 > php

본문 바로가기
사이트 내 전체검색

php

[ php ] PHP에서 CSV 로 내보내기

페이지 정보

작성자 웹지기 댓글 0건 조회 10,964회 작성일 18-09-28 13:25

본문

csv 아웃풋용 파일을 하나 만들어두시고 링크

----------------------------------------------------------------------------------------------- 

- csv_output.php 

[code]

<? 

include "환경 설정 파일들"; 


// DB를 정의합니다. 여기서는 DB 클래스 파일을 include해서 사용했습니다. 

$DB = new DB_Mysql($WEB_HOST,$WEB_USER,$WEB_PASS,$WEB_DB); 


// 내보낼 데이터를 가져옵니다. 

$sql = "select * from 테이블명 order by idx desc"; 

$DB->query($sql); 


// CSV 파일 최상단에 표기 할 내용입니다. 

$csv_dump .= "ID,UID,발송자,발송자메일주소,수신자ID,수신자UID,수신자메일주소,메일주소공개여부,메일내용,발송날짜,"; 

$csv_dump .= "\r\n"; 


// while 로 데이터를 변수에 쓸어 넣습니다 -_-; 

while ($row = $DB->fetch_array()) { 

    // CSV저장 시 CR+LF 및 , 표시가 있으면 안되므로 치환시킵니다. 

    $row[mail_txt] = str_replace("\r\n","",$row[mail_txt]); 

    $row[mail_txt] = str_replace(","," ",$row[mail_txt]); 


    // 행 값을 csv_dump 에 쓸어담습니다 -_-; 

    $csv_dump .= $row[UserID].","; 

    $csv_dump .= $row[UserUID].","; 

    $csv_dump .= $row[send_char].","; 

    $csv_dump .= $row[send_mail].","; 

    $csv_dump .= $row[re_UserID].","; 

    $csv_dump .= $row[re_UserUID].","; 

    $csv_dump .= $row[re_mail].","; 

    $csv_dump .= $row[mailagree].","; 

    $csv_dump .= $row[mail_txt].","; 

    $csv_dump .= $row[regdate].","; 

    $csv_dump .= "\r\n"; 

} // while문 종료 


// CSV 파일로 저장합니다. 파일명을 날짜를 붙여 생성합니다. 

$date = date("YmdHi"); 

$filename = "csvoutput_".$date.".csv"; 


header( "Content-type: application/vnd.ms-excel;charset=KSC5601" ); 

header("Content-Disposition: attachment; filename=$filename"); 

header( "Content-Description: PHP4 Generated Data" ); 


echo $csv_dump; 


$DB->close(); 

?> 

[/code]


데이터를 "(큰따옴표) 로 감싸면 ,(콤마)와 (엔터) 의 데이터도 인식합니다. 

데이터 안의 "(큰따옴표)를 ""(쌍큰따옴표)로 입력하면 데이터 안의 "(큰 따옴표)도 입력가능합니다. 

(ex: "데이터1","데이?,") 

위의 예에서 while 문만 

[code]

while(...) { 

    $csv_dump .='"'.implode('","', str_replace('"', '""', $row)).'"'."\n"; 

[/code]

정도로 입력하면 되겠네요. 

물론 implode 를 할때는 Select 질의시 필요한 필드(ex: select ID, USER...)를 선언해야 합니다.

adodb 를 쓰면 편하게 사용할수 있습니다. 

[code]

$rs = $CON->Execute($query); 

echo rs2csv($rs);

[/code]

추천0 비추천0

댓글목록

등록된 댓글이 없습니다.

Total 82건 3 페이지
  • 52 [ php ] fopen, fgets, fclose, fseek, ftell
  • 1. fopen, fgets, fcloselog 파일 또는txt나 csv로 된 DB파일을 불러올 때 쓰는 함수다.$file = 'log.txt'; // 불러올 파일명$f =fopen( $file, "r" ); // 파일을 열어 '읽기만' 한다. (포인터는 파일의 맨 처음)$line =fgets( $f, 4096 ); // 한 줄을 읽는다.echo $line; // 한 줄을 출력한다.fclose($f) // 파일을 닫는다.각 함...
  • 웹지기 09-30 5361 0 0 댓글 0
+1
  • 49 [ php ] 모든 언어를 나의 언어로 만들자!!!(베타버젼 입니다.) - 헌이님
  • 구글 번역이 유료화 되면서 마이크로 소프트사의 API 번역기를 이용하여 만들어 봤습니다.연동하기 시작한지는 좀 되었는데, 오늘 마무리를 합니다.유료화 하는 스킨인데요 ....... .오늘은 특별히 이런 저런 일이 많았습니다. 특히나군포돼지님과 좋은친분으로 갖기로한 나만의(?) 기념으로 올립니다.TEST http://linkma.kr/bbs/write.php?bo_table=Community유료자료실 http://linkma.kr/bbs/board.php?bo_table=SIR_SKIN2초보자를 위...
  • 웹지기 09-30 3437 0 0 댓글 0
  • 48 [ php ] [ class ] 클래스( Class ) 사용을 위한 기본 지식
  • 1. Class 란?클래스는 변수와 변수에 관계되는 함수로 이루어진 하나의 변수형이다.함수저장소 또는 비슷한 함수모음 이라고 이해하면 되겠다.2. Class의 기본 형태&lt;?phpclass Plan{ function testPlan() { echo(" Call to testPlan function!"); }}$skyplan =newPlan; // 객체변수를 생성하기 위해 new를 사용함$skyplan-&gt;testPlan(); // testPlan...
  • 웹지기 09-30 3374 0 0 댓글 0
  • 47 [ php ] [ class ] 클래스( class )에서 지시자( -> )의 의미
  • 객체는 자신만의 변수와 함수 가질 수 있습니다. 객체에서 변수, 함수는 각각 멤버변수 , 메쏘드 라고 불립니다.class test { var $a;// 멤버변수 (클래스 안에서 변수를 정의 할때는 var를 반드시 적어 주어야 한다.) var $b; function aaa() {// 메쏘드 (클래스안의 함수를 메쏘드 라고 한다.) $this-&gt;abcd = " 알파벳";// 메쏘드안에서 변수 정의할 때는 $this를 붙혀 준다. }}위와 같이 test 란 class 가...
  • 웹지기 09-30 19758 0 0 댓글 0
  • 45 [ php ] [ class ] Snoopy.class.php 를 이용하여 파일 긁어오기
  • 사이트를 긁어오기를 하다보면 fsockopen(): unable to connect to 라는 에러가 나면서 사이트 긁어오기가 되지 않는 경우가 종종있다.특히 외국 사이트중에 그런 곳이 많다. 사이트를 방문하지 않고 내용만 쏙 빼가는게 탐탁치 않아서 막아 놓은경우도 있고, 국가적인 차원에서 차단을 시킨경우도 있다.예를 들어 , 일본 최대 AV 회사중에 하나인 DMM은 한국에서 들어오는 방문자를 차단시켜놓았다. 실제로 AV를 구매하지도 않으면서 트래픽은 엄청나게 잡아 먹기 때문이다.또 다른예로 , ...
  • 웹지기 09-30 6428 0 0 댓글 0
  • 44 [ php ] Text Files 핸들링
  • 파일명 menu.ini회사소개,인사말씀,조직도,오시는길제품소개,가전제품,주방제품,욕실제품고객센터,A/S안내,불만접수,1:1게시판커뮤니티,공지사항,자유게시판,이용후기예제 1[code]$File = file('./menu.ini');echo $File;결과 : file 함수는 파일을 읽어서 배열로 반환하는 것을 알 수 있다.결과 array[/code]예제 2첫번째 배열을 출력[code]$File = file('./menu.ini');echo $File[0];결과 : 역시 파일의 전체 내용을 배열로 읽...
  • 웹지기 09-30 3120 0 0 댓글 0
  • 43 [ php ] glob 이용 패턴으로 파일 include 하기
  • [code]$library = array_merge( glob('**/*.class.php'));foreach($library as $lib) include_once $lib;[/code]PHP프레임워크를 제작하던 중 쓰던 방법glob 로 패턴으로나온 리스트를 array로 담고 그걸 merge로 합쳐서 include 하는 형태[code]array glob ( string $pattern [, int $flags= 0 ] )[/code]
  • 웹지기 09-28 3887 0 0 댓글 0
  • 42 [ php ] 자료형 비교표 gettype(), empty(), is_null(), isset(), bool…
  • __EXPRESSION__gettype()empty()is_null()isset()boolean:if($x)$x = "";stringTRUEFALSETRUEFALSE$x = null;NULLTRUETRUEFALSEFALSEvar $x;NULLTRUETRUEFALSEFALSE$xis undefinedNULLTRUETRUEFALSEFALSE$x = array();arrayTRUEFALSETRUEFALSE$x = false;booleanTRUEFALSETRUEFALSE$x = true...
  • 웹지기 09-28 5040 0 0 댓글 0
  • 열람중 [ php ] PHP에서 CSV 로 내보내기
  • csv 아웃풋용 파일을 하나 만들어두시고 링크------------------------------------------------------------------------------------------------ csv_output.php[code]&lt;?include "환경 설정 파일들";// DB를 정의합니다. 여기서는 DB 클래스 파일을 include해서 사용했습니다.$DB = new DB_Mysql($WEB_HOST,$WEB_USER,$WEB_PASS,$W...
  • 웹지기 09-28 10965 0 0 댓글 0
  • 40 [ php ] allow_url_fopen = off 일때 url파일읽기
  • php.ini 파일에 allow_url_fopen=on으로 설정되어 있으면, URL 주소로 파일 읽어올 때 다음과 같이 처리하지만 allow_url_fopen=off로 설정되어 있는 경우, 일단 php.ini 파일을 수정그러나 웹호스팅을 하는 경우 php.ini 파일을 직접 수정할 수 없는 경우가 있다.이런 경우의 해결책을 찾아보니 다음과 같이 socket을 이용해 URL주소를 읽어오는 방법[code]&lt;?php$url = "URL 주소";$info = parse_u...
  • 웹지기 09-28 5859 0 0 댓글 0
+3
  • 39 [ php ] php 에서 xml 사용하기
  • php에서 사용하기SimpleXML SimpleXML 모듈은 사용자가 쉽게 XML문서를 객체화 시켜 사용 가능 요구사항 : PHP5 XML James Clark의 expat를 사용. XML 문서를 처리할 수 있게 하지만, 유효성을 검증하지는 않음 요구사항 : PHP를 아파치 1.3.9 이상의 모듈로 컴파일 expat 설치 =&gt; http://www.jclark.com/xml/expat.htmlDOM XML문서를 DOM API 로 제공함 요구사항 : java VM이 설...
  • 웹지기 09-27 4793 0 0 댓글 0
게시물 검색

회원로그인

접속자집계

오늘
1,792
어제
15,369
최대
33,828
전체
8,338,582

그누보드5
Copyright © funyphp.com. All rights reserved.