php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 07-01-2003, 13:54
Tamtam
 Newbie
Links : Onlinestatus : Tamtam ist offline
Registriert seit: Jan 2003
Beiträge: 17
Tamtam ist zur Zeit noch ein unbeschriebenes Blatt
Standard mit php aus einer csv datei lesen?

hi wie kann man aus einer csv datei lesen? grundsätzliches wie man dateien liest und schreibt weiss ich, aber was muss ich anwenden für csv`s?

ich hab hier eine csv in der es wie folgt aussieht:
NR; Gehalt; Alter; Beruf;
1;3000;32;Meister;

wie kann ich nun auf die einzelnen Punkte zugreifen um sie z.b in eine tabelle über php einzulesen?

danke
T
Mit Zitat antworten
freelancermap.de - IT Projektvermittlung für Selbständige und Freiberufler
  #2 (permalink)  
Alt 07-01-2003, 13:59
tj99de
 PHP Junior
Links : Onlinestatus : tj99de ist offline
Registriert seit: Feb 2002
Beiträge: 658
tj99de ist zur Zeit noch ein unbeschriebenes Blatt
tj99de eine Nachricht über ICQ schicken
Standard

Hi!
Dafür gibt es bestimmt irgentwo eine optimierte Funktion, schau mal bei den snipets nach.
Von der Grundidee würde ich die Datei mit der Funktion file()j zeilenweise einlesen und mit der Funktion split () bei jedem ; aufspalten.
Die 1. Zeile der Datei gibt Dir dann die Variablennamen (egal wieviele es sind) und alle folgenden Zeilen (egal wieviel es sind) jeweils einen Datensatz für die Variablen aus Zeile 1.
Wenn Du das ganze in eine Schleife steckst kannst Du auch gleich jeden Datensatz verarbeiten (z.B. in DB schreiben)
cu tj99de
__________________
Of all things I've lost
I miss my mind the most
Mit Zitat antworten
  #3 (permalink)  
Alt 07-01-2003, 21:59
Titus
 PHP Master
Links : Onlinestatus : Titus ist offline
Registriert seit: Jan 2001
Ort: im Rodgau
Beiträge: 4.292
Titus ist zur Zeit noch ein unbeschriebenes Blatt
Arrow

fgetcsv (int $filepointer, int $length[, string $delimimiter]
__________________
mein Sport: mein Frühstück: meine Arbeit:

Sämtliche Code-Schnipsel sind im Allgemeinen nicht getestet und werden ohne Gewähr auf Fehlerfreiheit und Korrektheit gepostet.
Mit Zitat antworten
  #4 (permalink)  
Alt 09-01-2003, 17:12
faustus
 Registrierter Benutzer
Links : Onlinestatus : faustus ist offline
Registriert seit: May 2002
Ort: Ingolstadt
Beiträge: 188
faustus ist zur Zeit noch ein unbeschriebenes Blatt
Standard

PHP-Code:
CSV Reader, egal wie viele felder eine CSV hat

so sieht das csv aus:

rubrik,titel,code
SPORT,HAND2,HAND2
SPORT,FOOTBKIT,FOOTBKIT
SPORT,LGDUDA,LGDUDA
SPORT,THEBALL2,THEBALL2
SPORT,FOOTBAL6,FOOTBAL6
SPORT,BIKEMAN,BIKEMAN
SPORT,2FAST4U,2FAST4U
SPORT,RACE,RACE
SPORT,THEBAIT,THEBAIT
SPORT,FLEAGOAL,FLEAGOAL
SPORT,GOLFBALL,GOLFBALL
SPORT,GYMGIRL,GYMGIRL
SPORT,HOOPS,HOOPS
SPORT,SLAPSHOT,SLAPSHOT
SPORT,ROOK,ROOK
SPORT,SWIMSUIT,SWIMSUIT
SPORT,GYMKIT,GYMKIT
SPORT,TENNIKIT,TENNIKIT
FEELINGS,WINGED,WINGED
FEELINGS,LOVEPAIR,LOVEPAIR
FEELINGS,LIPS2,LIPS2

<?


# NEW MODULE CSV to array


// opens the file at row 1
$row 1;
$fp fopen ($MOD_src_path.$MOD_src,"r");

// reading data

$counter 0;

while (
$srccsv fgetcsv ($fp1000",")) {

    
$num count ($srccsv);
    
    
//generating rubrik for e.g. $data[1][rubrik] by reading the first line
    
if ($counter == ){
            for (
$c=0$c $num$c++) {
            
$format[$c] = $srccsv[$c];
            
//TEST echo $format[$c];
            
}
    }
    else {
    
//generating an array with all data from csv in the structure echo $data[0][rubrik]="sport";
        
for ($c=0$c $num$c++) {
                
$data[$counter][$format[$c]] = $srccsv[$c];
                
                
//TEST echo "<br>".$format[$c].$counter."-->".$data[$counter][$format[$c]];
        
}
    }
    
//TEST echo"format hat:".count($format);
//TEST print_r($format);
    
// This is the structure which is generated
//$data[x][rubrik] = "....2";
//$data[x][name] = "....2";
//$data[x][code] = "....2";
//$data[x][...] = "....2";

    
$counter++;
}
fclose ($fp);

        
//TEST 
        //print_r($data);
        //$test = count($data); echo $test; 
        
# END MODULE

        
?>
csv shower für obige datei, einfach beide in eine datei9 mit include ziehen


PHP-Code:
<?

# PART1 Filter a special one
    
// Filter "$search" "$in" of CSV "$data"

  
$search "SPORT"//sucht ein wort um es zu filtern aus einem feld
  
$in "rubrik"//rubrik ist es bei meiner csv datei kath,rubrik,name ist aber bei anderen csv anders
  
unset ($filtered);
  
$show_rows "3"//man kann nur beliebig viele zeilen anzeigen lassen statt alle
  
$more "init.php?settings=operator_all.inc.php&search=".$search//link to full data page
   
 /*    
  function csvFilter($filter) {
      global $search, $in;
    return ($filter[$in] == $search);
  }

  //echo "Ergebnis :\n";
  $filtered = array_filter($data, 'csvFilter'); 
  
  
 //TEST  print_r($filtered);
*/

 //This is the filter method to be used if php under 4.03 as not supporting array_filter argument
 
$number 0;
for (
$c=0$c count($data); $c++){
        if(
$search == $data[$c][$in]){
        
                for (
$b=0$b count($format); $b++) { //$ format contains rubrik, name, code, etc.
                
$filtered[$number][$format[$b]] = $data[$c][$format[$b]]; 
                
//extract "$search $in" | $c-1 as first row is CSVstructure
                
}
        
$number++;
        }
        
//TEST echo "Found ".$filtered[$c-1][$in]."<br>";
        //TEST elseif($search != $data[$c][$in]){echo "No item found at ".$c." as data is ".$data[$c][$in]."<br>";}
}    
        
//TEST print_r($filtered);
        //TEST echo "Size ".count($filtered)."<br>";
        
        //TEST echo"format hat:".count($format);
        //TEST print_r($format);


# NEW MODULE View

# View filtered from mod csv_filter.php

    
echo"<table border=0 width=100% cellspacing=0 cellpadding=2>";
    echo 
"<tr><td colspan=".count($format).">".$search."</td></tr>";
    
//generating <td>
    
    
if ($show_rows == ""){ //checks if you want to show less or all data in filtered
    
$show_rows count($filtered);
    
$show_more "";
    }
    else{
    
$show_more "<a class=linklist href=\"".$more."\"><img src=\"http://www.o2online.de/images/o2/linklist_arrow_orange.gif\" width=\"9\" height=\"10\" border=\"0\" alt=\"mehr ...\"> weitere</a>";
    }
    
    
    
//View different colors for each table row        

$colorpar=1//selection parameter for table row color parameter 1/0
    
for ($c=0$c $show_rows $c++) {
        
    
//selects the table color
    
if ($colorpar==0){    
    echo 
"<tr bgcolor=#ffffff>\n";
    
$colorpar=1;
    }
    else {
    echo 
"<tr bgcolor=#EBF7F7>\n";
    
$colorpar=0;
    }

    for (
$b=1$b count($format); $b++) { 
    
//$ format contains rubrik, name, code, etc. HERE YOU CAN MINIMISE by getting $b started as 1 etc.
            
       
if ($b == 1){
        echo 
"<td class=txt>"."<img src=\"".$MOD_src_path.strtolower($MOD_img.$filtered[$c][$format[$b]]).".gif\">"."</td>\n";
        }
        else {
        echo 
"<td class=\"CopyBlue\">".$filtered[$c][$format[$b]]."</td>\n";
        }
            }
        
    echo
"</tr>";
    }
    if (
$show_more != ""){ 
    echo 
"<tr><td colspan=".$b.">".$show_more."</td></tr>";
    }
    
     echo
"</table>";
    
    
    
    
?>
__________________
Gruß,

faustus
____________________

Programmieren ist manchmal genauso logisch, wie die Zukunft aus einem Kaffeesatz auszulesen ...

Geändert von faustus (09-01-2003 um 17:22 Uhr)
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

PHP Marktplatz-Software
PHP Marktplatz-SoftwareEs hat sich viel getan! Die neue Version 7.5.9 unserer PHP Marktplatz-Software ebiz-trader steht ab sofort zur Verfügung.

28.10.2019 | Berni

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni


 

Aktuelle PHP Scripte

SMT

Server Monitoring & Management Tool Das SMT wurde von einem Administrator für Administratoren entwickelt, es vereinfacht den Alltag in der klassischen Administration und Verwaltung. Mit dem SMT kannst Du alle Deine Server & Dienste verwalten und überwach

09.10.2020 palle_1977 | Kategorie: PHP
phplinX-Erotikportal 4 ansehen phplinX-Erotikportal 4

Erweiterbares Portal speziell für Erotik mit den Modulen Webkatalog, Bannermanagement und Kleinanzeigenmarkt. Sämtliche Module können über einen einzigen Adminbereich verwaltet werden.

18.06.2020 Cosinus14 | Kategorie: PHP/ Anzeigenmarkt
Erotik-Portal

Mit unsererem Erotik-Portal erhalten Sie ein komplettes Internetprojekt inklusive einer bedienerfreundlichem Administration sowie zahlreichen wichtigen Funktionen. Unser auf PHP und MySQL basierendes Script bietet Ihnen - und Ihren Besuchern - komfort

18.06.2020 ISD-Genthin | Kategorie: PHP/ Anzeigenmarkt
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 20:03 Uhr.