<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://wbex.ru/index.php?action=history&amp;feed=atom&amp;title=PHP%2FFile_Directory%2FCSV_File</id>
		<title>PHP/File Directory/CSV File - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://wbex.ru/index.php?action=history&amp;feed=atom&amp;title=PHP%2FFile_Directory%2FCSV_File"/>
		<link rel="alternate" type="text/html" href="http://wbex.ru/index.php?title=PHP/File_Directory/CSV_File&amp;action=history"/>
		<updated>2026-04-05T12:07:27Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://wbex.ru/index.php?title=PHP/File_Directory/CSV_File&amp;diff=472&amp;oldid=prev</id>
		<title> в 10:37, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://wbex.ru/index.php?title=PHP/File_Directory/CSV_File&amp;diff=472&amp;oldid=prev"/>
				<updated>2010-05-26T10:37:33Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 10:37, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://wbex.ru/index.php?title=PHP/File_Directory/CSV_File&amp;diff=473&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://wbex.ru/index.php?title=PHP/File_Directory/CSV_File&amp;diff=473&amp;oldid=prev"/>
				<updated>2010-05-26T07:04:23Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==fgetcsv.php==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
   $fh = fopen(&amp;quot;s.csv&amp;quot;, &amp;quot;r&amp;quot;);&lt;br /&gt;
   while (list($name, $email, $phone) = fgetcsv($fh, 1024, &amp;quot;,&amp;quot;)) {&lt;br /&gt;
      echo &amp;quot;&amp;lt;p&amp;gt;$name ($email) Tel. $phone&amp;lt;/p&amp;gt;&amp;quot;;&lt;br /&gt;
   }&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Generating comma-separated data==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
$sales = array( array(&amp;quot;Northeast&amp;quot;,12.54),&lt;br /&gt;
                array(&amp;quot;All Regions&amp;quot;,1597.34) );&lt;br /&gt;
$fh = fopen(&amp;quot;sales.csv&amp;quot;,&amp;quot;w&amp;quot;) or die(&amp;quot;Can&amp;quot;t open sales.csv&amp;quot;);&lt;br /&gt;
foreach ($sales as $sales_line) {&lt;br /&gt;
    if (fputcsv($fh, $sales_line) === false) {&lt;br /&gt;
        die(&amp;quot;Can&amp;quot;t write CSV line&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
fclose($fh) or die(&amp;quot;Can&amp;quot;t close sales.csv&amp;quot;);&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Making a CSV-formatted string==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
function make_csv_line($values) {&lt;br /&gt;
    foreach($values as $i =&amp;gt; $value) {&lt;br /&gt;
        if ((strpos($value, &amp;quot;,&amp;quot;)  !== false) ||&lt;br /&gt;
            (strpos($value, &amp;quot;&amp;quot;&amp;quot;)  !== false) ||&lt;br /&gt;
            (strpos($value, &amp;quot; &amp;quot;)  !== false) ||&lt;br /&gt;
            (strpos($value, &amp;quot;\t&amp;quot;) !== false) ||&lt;br /&gt;
            (strpos($value, &amp;quot;\n&amp;quot;) !== false) ||&lt;br /&gt;
            (strpos($value, &amp;quot;\r&amp;quot;) !== false)) {&lt;br /&gt;
            $values[$i] = &amp;quot;&amp;quot;&amp;quot; . str_replace(&amp;quot;&amp;quot;&amp;quot;, &amp;quot;&amp;quot;&amp;quot;&amp;quot;, $value) . &amp;quot;&amp;quot;&amp;quot;;&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    return implode(&amp;quot;,&amp;quot;, $values) . &amp;quot;\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Parsing CSV Strings==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
function parse_csv($string, $delim = &amp;quot;,&amp;quot;, $quote=&amp;quot;&amp;quot;&amp;quot;) {&lt;br /&gt;
    $new = str_replace(&amp;quot;{$quote}{$quote}&amp;quot;, $quote, $string);&lt;br /&gt;
    $matches = array();&lt;br /&gt;
    preg_match_all(&amp;quot;/\s*({$quote}?)(.*?)\\1\s*(?:{$delim}|$)/&amp;quot;,&lt;br /&gt;
        $new, $matches);&lt;br /&gt;
    array_pop($matches[2]);&lt;br /&gt;
    return $matches[2];&lt;br /&gt;
}&lt;br /&gt;
$str = &amp;quot;c &amp;quot;s&amp;quot;&amp;quot;v&amp;quot;&amp;quot;&amp;quot;,&amp;quot;s&amp;quot;, &amp;quot;f\ny&amp;quot; &amp;quot;;&lt;br /&gt;
$values = parse_csv($str);&lt;br /&gt;
echo &amp;quot;&amp;lt;pre&amp;gt;&amp;quot;;&lt;br /&gt;
print_r($values);&lt;br /&gt;
echo &amp;quot;&amp;lt;/pre&amp;gt;&amp;quot;;&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Printing comma-separated data==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
$sales = array( array(&amp;quot;Northeast&amp;quot;,12.54),&lt;br /&gt;
                array(&amp;quot;All Regions&amp;quot;,12.34) );&lt;br /&gt;
$fh = fopen(&amp;quot;php://output&amp;quot;,&amp;quot;w&amp;quot;);&lt;br /&gt;
foreach ($sales as $sales_line) {&lt;br /&gt;
    if (fputcsv($fh, $sales_line) === false) {&lt;br /&gt;
        die(&amp;quot;Can&amp;quot;t write CSV line&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
fclose($fh);&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Putting comma-separated data into a string==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
$sales = array( array(&amp;quot;Northeast&amp;quot;,12.54),&lt;br /&gt;
                array(&amp;quot;All Regions&amp;quot;,1597.34) );&lt;br /&gt;
ob_start();&lt;br /&gt;
$fh = fopen(&amp;quot;php://output&amp;quot;,&amp;quot;w&amp;quot;) or die(&amp;quot;Can&amp;quot;t open php://output&amp;quot;);&lt;br /&gt;
foreach ($sales as $sales_line) {&lt;br /&gt;
    if (fputcsv($fh, $sales_line) ===  false) {&lt;br /&gt;
        die(&amp;quot;Can&amp;quot;t write CSV line&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
fclose($fh) or die(&amp;quot;Can&amp;quot;t close php://output&amp;quot;);&lt;br /&gt;
$output = ob_get_contents();&lt;br /&gt;
ob_end_clean();&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Read csv file==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
$fh = fopen(&amp;quot;csvdata.csv&amp;quot;, &amp;quot;rb&amp;quot;);&lt;br /&gt;
if (! $fh) {&lt;br /&gt;
    die(&amp;quot;Can&amp;quot;t open csvdata.csv: $php_errormsg&amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
print &amp;quot;&amp;lt;table&amp;gt;\n&amp;quot;;&lt;br /&gt;
       &lt;br /&gt;
for ($line = fgetcsv($fh, 1024); ! feof($fh); $line = fgetcsv($fh, 1024)) {&lt;br /&gt;
    print &amp;quot;&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;&amp;quot; . implode(&amp;quot;&amp;lt;/td&amp;gt;&amp;lt;td&amp;gt;&amp;quot;, $line) . &amp;quot;&amp;lt;/td&amp;gt;&amp;lt;/tr&amp;gt;\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
print &amp;quot;&amp;lt;/table&amp;gt;&amp;quot;;&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Reading CSV data from a file==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
$fp = fopen(&amp;quot;data.csv&amp;quot;,&amp;quot;r&amp;quot;) or die(&amp;quot;can&amp;quot;t open file&amp;quot;);&lt;br /&gt;
print &amp;quot;&amp;lt;table&amp;gt;\n&amp;quot;;&lt;br /&gt;
while($csv_line = fgetcsv($fp)) {&lt;br /&gt;
    print &amp;quot;&amp;lt;tr&amp;gt;&amp;quot;;&lt;br /&gt;
    for ($i = 0, $j = count($csv_line); $i &amp;lt; $j; $i++) {&lt;br /&gt;
        print &amp;quot;&amp;lt;td&amp;gt;&amp;quot;.htmlentities($csv_line[$i]).&amp;quot;&amp;lt;/td&amp;gt;&amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    print &amp;quot;&amp;lt;/tr&amp;gt;\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
print &amp;quot;&amp;lt;/table&amp;gt;\n&amp;quot;;&lt;br /&gt;
fclose($fp) or die(&amp;quot;can&amp;quot;t close file&amp;quot;);&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Tell the web client to view the CSV file in a seprate program==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;html4strict&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
header(&amp;quot;Content-Disposition: attachment; filename=&amp;quot;dishes.csv&amp;quot;&amp;quot;);&lt;br /&gt;
  &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>