PHP Script zum CSV Upload anpassen
Hallo
ich habe im Internet in Script gefunden und angepasst,
welches mir eine CSV Datei in eine Datenbank einliesst.
Ihr findet es hier:
http://nopaste.debianforum.de/36255
Aber jetzt mein Problem
Ich muss nochmal eine CSV Datei einlesen. Aber jetzt nach diesem Muster:
Aussehen CSV Datei:
Artikelnummer;Menge
ABC;10
DEF;20
...
Das heisst das Script müsste jetzt schauen, in welcher Spalte ist Artikel=ABC und setzt dort dann Menge auf den entsprechenden Wert.
Im reinen SQL sähe das wohl so aus:;
UPDATE ArtikelTabelle SET Artikelmenge=$menge WHERE Artikelnummer=$artnr;
Damit denke ich würd ich in der Tabelle "ARtikeltabelle" schauen, wo die Artikelnummer ist und dort das Feld Menge ändern.
Aber das muss nun in die PHP Datei so das er die ganze CSV der Reihe nach durchläuft und
die Werte in die DAtenbank einpflegt.
Danke schonmal für die Hilfe !!!
ich habe im Internet in Script gefunden und angepasst,
welches mir eine CSV Datei in eine Datenbank einliesst.
Ihr findet es hier:
http://nopaste.debianforum.de/36255
Aber jetzt mein Problem
Ich muss nochmal eine CSV Datei einlesen. Aber jetzt nach diesem Muster:
Aussehen CSV Datei:
Artikelnummer;Menge
ABC;10
DEF;20
...
Das heisst das Script müsste jetzt schauen, in welcher Spalte ist Artikel=ABC und setzt dort dann Menge auf den entsprechenden Wert.
Im reinen SQL sähe das wohl so aus:;
UPDATE ArtikelTabelle SET Artikelmenge=$menge WHERE Artikelnummer=$artnr;
Damit denke ich würd ich in der Tabelle "ARtikeltabelle" schauen, wo die Artikelnummer ist und dort das Feld Menge ändern.
Aber das muss nun in die PHP Datei so das er die ganze CSV der Reihe nach durchläuft und
die Werte in die DAtenbank einpflegt.
Danke schonmal für die Hilfe !!!
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 180757
Url: https://administrator.de/contentid/180757
Ausgedruckt am: 22.11.2024 um 09:11 Uhr
1 Kommentar
Hallo Frindly,
hatte unerwartet noch etwas Zeit und habe mich einfach mal dran probiert...
Auf das Genudel von Debian-Pastebin hatte ich keine Lust und habe es deswegen einfach komplett geschrieben - __allerdings hier im Editor__ !
keine Formatierungen, null Kommentare und so etwas wie: erst Datei öffnen und dann feststellen (anhand der Dateigröße) das die Datei doch leer ist...
Also das ist wie gesagt hier im Editor so aus meinem Ärmel gefallen und dementsprechend auch UNGETESTET !
Auch wenn es besten Gewissen entsprungen ist, so ist die Verwendung auf eigene Gefahr !
Allerdings solltest du es SO laufen lassen können weil es SO nur Ausgaben erzeugt und nicht an die Datenbank sendet. Die entsprechenden Stellen habe ich im Quelltext entsprechend kommentiert ;)
Wenn alles klappt und ich __keinen Fehler gemacht haben sollte__, solltest du eine Ausgabe ungefähr dieser bekommen:
Tja, hoffe es funktioniert und hilf dir *fg*
Eine gute Nacht
~Arano
Edit: Ohja, wie schön ist meine IDE *g*
hatte unerwartet noch etwas Zeit und habe mich einfach mal dran probiert...
Auf das Genudel von Debian-Pastebin hatte ich keine Lust und habe es deswegen einfach komplett geschrieben - __allerdings hier im Editor__ !
keine Formatierungen, null Kommentare und so etwas wie: erst Datei öffnen und dann feststellen (anhand der Dateigröße) das die Datei doch leer ist...
Also das ist wie gesagt hier im Editor so aus meinem Ärmel gefallen und dementsprechend auch UNGETESTET !
Auch wenn es besten Gewissen entsprungen ist, so ist die Verwendung auf eigene Gefahr !
Allerdings solltest du es SO laufen lassen können weil es SO nur Ausgaben erzeugt und nicht an die Datenbank sendet. Die entsprechenden Stellen habe ich im Quelltext entsprechend kommentiert ;)
Wenn alles klappt und ich __keinen Fehler gemacht haben sollte__, solltest du eine Ausgabe ungefähr dieser bekommen:
Quelle: mengenProArtikel.csv
SET Artikel1 = 875
SET Artikel2 = 34
SET Artikel3 = 1962
Fertig, 3 ArtNr-Mengen-Paare durchlaufen ...
SET Artikel1 = 875
SET Artikel2 = 34
SET Artikel3 = 1962
Fertig, 3 ArtNr-Mengen-Paare durchlaufen ...
Tja, hoffe es funktioniert und hilf dir *fg*
Eine gute Nacht
~Arano
<?php
$strCSVFile = 'mengeProArtikel.csv';
$strMyHost = 'localhost';
$strMyUser = 'eingeschraenkterbenutzer';
$strMyPass = 'ein_geheimes_passwort';
$strMyDaBa = 'datenbankname';
$strMyArtikelTab = 'ArtikelTabelle';
$hndMysql = mysql_connect( $strMyHost, $strMyUser, $strMyPass );
if( !is_resource($hndMysql) )
die( 'Die Verbindung zum Datenbankserver konnte nicht hergestellt werden' );
if( !mysql_select_db($strMyDaBa, $hndMysql) )
die( 'Die Datenbank konnte nicht geöffnet werden !' );
// Lese Datei zeilenweise (ArtNr-Mengen-Paare) in ein Array
$arrArtikel = file( $strCSVFile );
if( !is_array($arArtikel) )
die( 'Die CSV-Datei "'.$strCSVFile.'" konnte nicht gelesen werden !' );
echo 'Quelle: '.$strCSVFile.'<br><br>';
// Bearbeite jedes ArtNr-Mengen-Paar
foreach( $arrArtikel as $strMengeProArtikel )
{
// Teile ArtNr-Menge-Paar
list( $mixArtNr, $intMenge ) = explode( ';', $strMengeProArtikel );
$strUpdQuery = "UPDATE `".$strMyArtikelTab."`
SET `Artikelmenge` = '".$intMenge."'
WHERE `Artikelnummer` = '".$mixArtNr."'
LIMIT 1";
// DEBUGAUSGABE, wenn es funktioniert auskommentieren... ...oder nicht...
echo 'Artikelnummer: '.$mixArtNr.' = '.$intMenge.'<br>';
echo 'Query: '.$strUpdQuery.'<br>';
$bolDBUpdate = TRUE;
// DEBUGAUSGABE ENDE
// Sende Updatequery an Datenbank
// wenn die Debugausgabe gut aussieht, EINkommentieren - auf __eigene__ Gefahr !!
# $bolDBUpdate = @mysql_query( $strUpdQuery, $hndMysql );
if( FALSE===$bolDBUpdate )
{
// Ein Fehler ist aufgetreten, gebe Fehlermeldung aus und beende Script !
echo 'ERROR bei Artikelnummer: '.$mixArtNr.', '.mysql_error( $hndMysql );
exit();
}
// Das DB-Update war erfolgreich
echo 'SET Artikelnummer: '.$mixArtNr.' = '.$intMenge.'<br>';
}
// Alle Paare durchlaufen, fertig !
echo '<br><b>Fertig</b>, '.count( $arrArtikel ).' ArtNr-Mengen-Paare durchlaufen ...und hoffentlich in der DB aktualisiert...';
?>
Edit: Ohja, wie schön ist meine IDE *g*