Re: file/array manipulation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Mignon Hunter wrote:
Ok I got this to work but I'm not sure how -- and am having trouble re-producing the data:

My script I have so far is:

$lines = file('test2.csv');
foreach ($lines as $line) {
$line_split = explode(",", $line);
if(!(empty($line_split[0]) ) ){
//echo "I'm not empty";
$new_array = array(
$line_split[0] => $line_split[1]
); }
print("<pre>");
print_r($new_array);
print("</pre>");
//echo "<tr><td>" . $new_array[0] . "</td><td>" . $new_array[1] . "</td></tr>";// this doesnt work
}


Here's what the printed format spits out (abbreviated):

Array
(
    [R] => "ABC company
)
Array
(
    [R] => "ABC company
)
Array
(
    [R] => "ABC company
)
Array
(
    [R] => "ABC company
)
Array
(
    [O] => XYZ company
)
Array
(
    [O] => XYZ company
)
Array
(
    [O] => XYZ company
)
Array
(
    [O] => XYZ company
)

So - I'm getting the write letters assigned to write companys which is great. But my echo line:

echo "<tr><td>" . $new_array[0] . "</td><td>" . $new_array[1] . "</td></tr>";// this doesnt work

given the array you printed above:

<?php

foreach ($new_array as $k => $v) {
	echo "<tr><td>{$k}</td><td>{$v}</td></tr>";
}


Do I have several arrays or a multidim array?

you create a single array for each line of the csv file. each array contains one item. what you have done is assign the first field's value as the key of the array item, and the second field's value as the array items value.

$t = array( "R" => "ABC company"); // array with 1 item, using associative key
var_dump($t[ "R" ],$t[ 0 ]);

$t = array( "R" , "ABC company");  // array with 2 items, using implicit numeric keys
var_dump($t[ "R" ],$t[ 0 ]);


Thanks for any guidance


"Richard Lynch" <ceo@xxxxxxxxx> 03/15/05 10:39AM >>>


Hello

I'm trying to manipulate a text(.csv) file using php. I've read the file
and can print each line,
but I need to write where column A is missing

ColumnA    ColumnB

R                ABC company
                 ABC company
                 ABC company
                 ABC company
O                XYZ company
                  XYZ company
                  XYZ company
                  XYZ company

What I need to do is write a while loop (I think) to interate through the
lines and populate ColumnA
while ColumnB equals $var (ABC company, XYZ company), so that I end up
with:

ColumnA    ColumnB

R                ABC company
R                ABC company
R                ABC company
R                ABC company
O                XYZ company
O                XYZ company
O                XYZ company
O                XYZ company

Is this possible. What I've got so far to print out the file:

$lines = file('test2.csv');



$category = '';


// Loop through our array, and show line and numbers too.
foreach ($lines as $line_num => $line) {
 echo "Line #<b>{$line_num}</b> : " . $line . "<br />\n";


//Assuming it's the FIRST character of each line that has space or category:
//Check first character:
if ($line[0] != ' ' && $line[0] != "\t"){
  $category = $line[0];
}

echo "$category\t", trim(substr($line, 1)), "<br />\n";


}


Thanks in advance

--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php







-- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php


[Index of Archives]     [PHP Home]     [Apache Users]     [PHP on Windows]     [Kernel Newbies]     [PHP Install]     [PHP Classes]     [Pear]     [Postgresql]     [Postgresql PHP]     [PHP on Windows]     [PHP Database Programming]     [PHP SOAP]

  Powered by Linux