Array to csv or excel in php
Array to csv or excel in php
am 19.04.2010 15:45:00 von Manolis Vlachakis
--0015174be42edd836e0484972a29
Content-Type: text/plain; charset=ISO-8859-1
hallo there everyone..
i got an array from my database
Help with Code Tags
*PHP Syntax* (Toggle Plain Text
)
1. $save=split("[|;]",$listOfItems);
and what i want i s after making some changes to the attributes on the array
above to export them on an csv or excel format
but directly as a message to the browser ..
i dont want it to be saved on the server ...
what i cant understand from the examples i found on the net ..
is how to handle the files and which are created cause
i just have the array in a php file nothing more...
another thing i have in mind is to export from the ldap server the files
directly but seems to me as the wrong way to do it
thanks
--0015174be42edd836e0484972a29--
Re: Array to csv or excel in php
am 19.04.2010 17:00:45 von Andrew Ballard
On Mon, Apr 19, 2010 at 9:45 AM, Manolis Vlachakis
wrote:
> hallo there everyone..
> i got an array from my database
> Help with Code Tags
B_iframe=3Dtrue&height=3D400&width=3D680>
> *PHP Syntax* (Toggle Plain Text
..html#>
> )
>
>
> Â 1. $save=3Dsplit("[|;]",$listOfItems);
>
>
> and what i want i s after making some changes to the attributes on the ar=
ray
> above to export them on an csv or excel format
> but directly as a message to the browser ..
> i dont want it to be saved on the server ...
> what i cant understand from the examples i found on the net ..
> is how to handle the files and which are created cause
> i just have the array in a php file nothing more...
>
>
> another thing i have in mind is to export from the ldap server the files
> directly but seems to me as the wrong way to do it
>
> thanks
>
Often when outputting csv, I usually do something like this:
$fp =3D fopen('php://output', 'w') or die('Could not open stream');
foreach ($data as $row) {
// Assumes that $row will be an array.
// Manipulate the data in $row if necessary.
fputcsv($fp, $row);
}
?>
So far, it has worked pretty well and is much faster than any other
way I have found to output the CSV data by iterating through the
arrays manually.
Andrew
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Re: Array to csv or excel in php
am 19.04.2010 17:14:17 von Peter Lind
On 19 April 2010 17:00, Andrew Ballard wrote:
> On Mon, Apr 19, 2010 at 9:45 AM, Manolis Vlachakis
> wrote:
>> hallo there everyone..
>> i got an array from my database
>> Help with Code Tags
TB_iframe=3Dtrue&height=3D400&width=3D680>
>> *PHP Syntax* (Toggle Plain Text
7.html#>
>> )
>>
>>
>> Â 1. $save=3Dsplit("[|;]",$listOfItems);
>>
>>
>> and what i want i s after making some changes to the attributes on the a=
rray
>> above to export them on an csv or excel format
>> but directly as a message to the browser ..
>> i dont want it to be saved on the server ...
>> what i cant understand from the examples i found on the net ..
>> is how to handle the files and which are created cause
>> i just have the array in a php file nothing more...
>>
>>
>> another thing i have in mind is to export from the ldap server the files
>> directly but seems to me as the wrong way to do it
>>
>> thanks
>>
>
> Often when outputting csv, I usually do something like this:
>
>
>
> $fp =3D fopen('php://output', 'w') or die('Could not open stream');
>
> foreach ($data as $row) {
> Â Â // Assumes that $row will be an array.
> Â Â // Manipulate the data in $row if necessary.
> Â Â fputcsv($fp, $row);
> }
>
> ?>
An interesting idea. I'd do:
echo implode(',', $row);
regards
Peter
--=20
WWW: http://plphp.dk / http://plind.dk
LinkedIn: http://www.linkedin.com/in/plind
Flickr: http://www.flickr.com/photos/fake51
BeWelcome: Fake51
Couchsurfing: Fake51
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Re: Array to csv or excel in php
am 19.04.2010 17:40:55 von Andrew Ballard
On Mon, Apr 19, 2010 at 11:14 AM, Peter Lind wrote=
:
> On 19 April 2010 17:00, Andrew Ballard wrote:
>> On Mon, Apr 19, 2010 at 9:45 AM, Manolis Vlachakis
>>> 1. $save=3Dsplit("[|;]",$listOfItems);
>>>
>>> and what i want i s after making some changes to the attributes on the =
array
>>> above to export them on an csv or excel format
>>> but directly as a message to the browser ..
>>> i dont want it to be saved on the server ...
>>>
>> Often when outputting csv, I usually do something like this:
>>
>>
>>
>> $fp =3D fopen('php://output', 'w') or die('Could not open stream');
>>
>> foreach ($data as $row) {
>> Â Â // Assumes that $row will be an array.
>> Â Â // Manipulate the data in $row if necessary.
>> Â Â fputcsv($fp, $row);
>> }
>>
>> ?>
>
> An interesting idea. I'd do:
>
> echo implode(',', $row);
>
If it's very simple data that works, but it doesn't allow for the
optional enclosure characters that fputcsv() uses in cases where a
data element includes the column and/or row delimiter characters. I
had originally written something using an array_map callback that did
the optional enclosures as needed and then used echo implode() as you
suggest, but found the solution I posted was shorter and faster. YMMV
Andrew
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Re: Array to csv or excel in php
am 19.04.2010 17:52:27 von Peter Lind
On 19 April 2010 17:40, Andrew Ballard wrote:
> On Mon, Apr 19, 2010 at 11:14 AM, Peter Lind wro=
te:
>> On 19 April 2010 17:00, Andrew Ballard wrote:
>>> On Mon, Apr 19, 2010 at 9:45 AM, Manolis Vlachakis
>>>> Â 1. $save=3Dsplit("[|;]",$listOfItems);
>>>>
>>>> and what i want i s after making some changes to the attributes on the=
array
>>>> above to export them on an csv or excel format
>>>> but directly as a message to the browser ..
>>>> i dont want it to be saved on the server ...
>>>>
>>> Often when outputting csv, I usually do something like this:
>>>
>>>
>>>
>>> $fp =3D fopen('php://output', 'w') or die('Could not open stream');
>>>
>>> foreach ($data as $row) {
>>> Â Â // Assumes that $row will be an array.
>>> Â Â // Manipulate the data in $row if necessary.
>>> Â Â fputcsv($fp, $row);
>>> }
>>>
>>> ?>
>>
>> An interesting idea. I'd do:
>>
>> echo implode(',', $row);
>>
>
> If it's very simple data that works, but it doesn't allow for the
> optional enclosure characters that fputcsv() uses in cases where a
> data element includes the column and/or row delimiter characters. I
> had originally written something using an array_map callback that did
> the optional enclosures as needed and then used echo implode() as you
> suggest, but found the solution I posted was shorter and faster. YMMV
>
> Andrew
>
Yeah, was considering that point as well. I'd use the echo if the
array values are getting modified anyway. Otherwise your solution is
probably simpler.
Regards
Peter
--=20
WWW: http://plphp.dk / http://plind.dk
LinkedIn: http://www.linkedin.com/in/plind
Flickr: http://www.flickr.com/photos/fake51
BeWelcome: Fake51
Couchsurfing: Fake51
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Re: Array to csv or excel in php
am 19.04.2010 18:02:16 von Ken Guest
For non-simple data I have been using PEAR's File_CSV package. It's
proven itself very useful in
regards to not having to determine in my own code whether something
needs to be quoted etc etc - especially if the output CSV needs to be
wholly RFC 4180 compliant.
The documentation of it is rather minimal - at the moment you are
dependant on the test/example files and the API docs but grokking how
to use it is rather easy.
k.
On Mon, Apr 19, 2010 at 4:40 PM, Andrew Ballard wrote:
> On Mon, Apr 19, 2010 at 11:14 AM, Peter Lind wro=
te:
>> On 19 April 2010 17:00, Andrew Ballard wrote:
>>> On Mon, Apr 19, 2010 at 9:45 AM, Manolis Vlachakis
>>>> =A0 1. $save=3Dsplit("[|;]",$listOfItems);
>>>>
>>>> and what i want i s after making some changes to the attributes on the=
array
>>>> above to export them on an csv or excel format
>>>> but directly as a message to the browser ..
>>>> i dont want it to be saved on the server ...
>>>>
>>> Often when outputting csv, I usually do something like this:
>>>
>>>
>>>
>>> $fp =3D fopen('php://output', 'w') or die('Could not open stream');
>>>
>>> foreach ($data as $row) {
>>> =A0 =A0// Assumes that $row will be an array.
>>> =A0 =A0// Manipulate the data in $row if necessary.
>>> =A0 =A0fputcsv($fp, $row);
>>> }
>>>
>>> ?>
>>
>> An interesting idea. I'd do:
>>
>> echo implode(',', $row);
>>
>
> If it's very simple data that works, but it doesn't allow for the
> optional enclosure characters that fputcsv() uses in cases where a
> data element includes the column and/or row delimiter characters. I
> had originally written something using an array_map callback that did
> the optional enclosures as needed and then used echo implode() as you
> suggest, but found the solution I posted was shorter and faster. YMMV
>
> Andrew
>
> --
> PHP General Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>
--=20
http://blogs.linux.ie/kenguest/
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
RE: Array to csv or excel in php
am 19.04.2010 19:26:59 von Jay Blanchard
[snip] to export them on an csv or excel format[/snip]
Stupid browser tricks....
http://www.evolt.org/node/26896
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php