Software, your way.
burger menu icon
WillMaster

WillMasterBlog > PHP

FREE! Coding tips, tricks, and treasures.

Possibilities weekly ezine

Get the weekly email website developers read:

 

Your email address

name@example.com
YES! Send Possibilities every week!

Formatting CSV

"CSV" stands for "Comma-Separated Values". CSV is a popular plain text format often used especially for exporting and importing data to and from various spreadsheet software.

This article is for PHP programmers. I'll show you how to format CSV with PHP.

Do it with a function. Here is one that will do the trick.

function MakeCSVline($array)
{
   $formattedarray = array();
   foreach( $array as $chunk )
   {
      if( preg_match('/[\"\'\r\n\,]/',$chunk) )
      {
         $s = str_replace('"','""',$chunk);
         $formattedarray[] = '"' . $s . '"';
      }
      else { $formattedarray[] = $chunk; }
   }
   return implode(',',$formattedarray);
} # function MakeCSVline()

In a PHP script, call the function with an array of values. The function returns a line of CSV-formatted text.

Here is an example.

<?php
$testarray = array( 'chocolate', 'Tom "Smiley" Thumb', 'The fortune, the freedom' );
$CSVline = MakeCSVline($testarray);
echo $CSVline;
function MakeCSVline($array)
{
   $formattedarray = array();
   foreach( $array as $chunk )
   {
      if( preg_match('/[\"\'\r\n\,]/',$chunk) )
      {
         $s = str_replace('"','""',$chunk);
         $formattedarray[] = '"' . $s . '"';
      }
      else { $formattedarray[] = $chunk; }
   }
   return implode(',',$formattedarray);
} # function MakeCSVline()
?>

The example script turns this array:

Array
(
    [0] => chocolate
    [1] => Tom "Smiley" Thumb
    [2] => The fortune, the freedom
)

Into this CSV line:

chocolate,"Tom ""Smiley"" Thumb","The fortune, the freedom" 

The MakeCSVline() function handles multi-line values as well as values that contain quotation marks or commas.

The CSV-creating function is a handy little tool for you PHP programmers.

(This content first appeared in Possibilities newsletter.)

Will Bontrager

Was this blog post helpful to you?
(anonymous form)

Support This Website

Some of our support is from people like you who see the value of all that's offered for FREE at this website.

"Yes, let me contribute."

Amount (USD):

Tap to Choose
Contribution
Method


All information in WillMaster Blog articles is presented AS-IS.

We only suggest and recommend what we believe is of value. As remuneration for the time and research involved to provide quality links, we generally use affiliate links when we can. Whenever we link to something not our own, you should assume they are affiliate links or that we benefit in some way.

Recent Articles in the Library

Dropdown Links

I used to see many dropdown links during the earlier part of my internet experience.

On-Page Editing

Edit something on a web page and have it saved for display whenever the page is reloaded.

Automatic iFrame Sizing

When you pull content from the same domain into an iframe, the iframe can be resized automatically to accommodate the content.

Delayed Content Loading

Here is one way to delay loading of certain web page content.

End-of-year Automatic Copyright Change

Use PHP or JavaScript to set up an automatic update of the year number within a copyright statement.

PayPal Form Without Merchant ID

How to submit a form to PayPal without a Merchant ID.

Extracting Dates From the Unix Timestamp

The UNIX timestamp can be used to determine the represented time for any time zone on Earth.

How Can We Help You? balloons
How Can We Help You?
bullet Custom Programming
bullet Ready-Made Software
bullet Technical Support
bullet Possibilities Newsletter
bullet Website "How-To" Info
bullet Useful Information List

© 1998-2001 William and Mari Bontrager
© 2001-2011 Bontrager Connection, LLC
© 2011-2025 Will Bontrager Software LLC