Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

PHP Script zum CSV Upload anpassen

Frage Entwicklung PHP

Mitglied: frindly

frindly (Level 1) - Jetzt verbinden

20.02.2012 um 09:13 Uhr, 2978 Aufrufe, 1 Kommentar

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 !!!
Mitglied: Arano
20.02.2012 um 21:45 Uhr
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:
Quelle: mengenProArtikel.csv

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


01.
<?php 
02.
 
03.
$strCSVFile = 'mengeProArtikel.csv'
04.
$strMyHost = 'localhost'
05.
$strMyUser = 'eingeschraenkterbenutzer'
06.
$strMyPass = 'ein_geheimes_passwort'
07.
$strMyDaBa = 'datenbankname'
08.
$strMyArtikelTab = 'ArtikelTabelle'
09.
 
10.
$hndMysql = mysql_connect( $strMyHost, $strMyUser, $strMyPass ); 
11.
if( !is_resource($hndMysql) ) 
12.
    die( 'Die Verbindung zum Datenbankserver konnte nicht hergestellt werden' ); 
13.
if( !mysql_select_db($strMyDaBa, $hndMysql) ) 
14.
    die( 'Die Datenbank konnte nicht ge&ouml;ffnet werden !' ); 
15.
 
16.
// Lese Datei zeilenweise (ArtNr-Mengen-Paare) in ein Array 
17.
$arrArtikel = file( $strCSVFile ); 
18.
if( !is_array($arArtikel) ) 
19.
    die( 'Die CSV-Datei "'.$strCSVFile.'" konnte nicht gelesen werden !' ); 
20.
echo 'Quelle: '.$strCSVFile.'<br><br>'
21.
 
22.
// Bearbeite jedes ArtNr-Mengen-Paar 
23.
foreach( $arrArtikel as $strMengeProArtikel
24.
25.
    // Teile ArtNr-Menge-Paar 
26.
    list( $mixArtNr, $intMenge ) = explode( ';', $strMengeProArtikel ); 
27.
    $strUpdQuery = "UPDATE `".$strMyArtikelTab."
28.
                       SET `Artikelmenge` = '".$intMenge."' 
29.
                     WHERE `Artikelnummer` = '".$mixArtNr."' 
30.
                     LIMIT 1"; 
31.
 
32.
    // DEBUGAUSGABE, wenn es funktioniert auskommentieren...  ...oder nicht... 
33.
    echo 'Artikelnummer: '.$mixArtNr.' = '.$intMenge.'<br>'
34.
    echo 'Query: '.$strUpdQuery.'<br>'
35.
    $bolDBUpdate = TRUE; 
36.
    // DEBUGAUSGABE ENDE 
37.
 
38.
    // Sende Updatequery an Datenbank 
39.
    // wenn die Debugausgabe gut aussieht, EINkommentieren - auf __eigene__ Gefahr !! 
40.
    # $bolDBUpdate = @mysql_query( $strUpdQuery, $hndMysql ); 
41.
    if( FALSE===$bolDBUpdate
42.
43.
        // Ein Fehler ist aufgetreten, gebe Fehlermeldung aus und beende Script ! 
44.
        echo 'ERROR bei Artikelnummer: '.$mixArtNr.', '.mysql_error( $hndMysql ); 
45.
        exit(); 
46.
47.
 
48.
    // Das DB-Update war erfolgreich 
49.
    echo 'SET Artikelnummer: '.$mixArtNr.' = '.$intMenge.'<br>'
50.
51.
 
52.
// Alle Paare durchlaufen, fertig ! 
53.
echo '<br><b>Fertig</b>, '.count( $arrArtikel ).' ArtNr-Mengen-Paare durchlaufen  ...und hoffentlich in der DB aktualisiert...'
54.
 
55.
?>
Edit: Ohja, wie schön ist meine IDE *g*
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Shell dialog script anpassen
gelöst Frage von Tealk144Batch & Shell2 Kommentare

Also ich habe mir ein kleines Script zusammengeschrieben mit der "dialog" Funktion, nun würde ich gern wissen ob man ...

Batch & Shell
CSV Dateien auswerten mit Script
gelöst Frage von Crank69Batch & Shell8 Kommentare

Hallo Leute, habe ein Problem und hoffe ihr könnt mir helfen. Ich hoffe das die Bilder helfen bei meinem ...

Apache Server
Upload Problematik Mediawiki+Apache+PHP
Frage von m3n7orApache Server4 Kommentare

Hallo zusammen, ich beobachte aktuell auf unserem Webserver folgendes Problem. Wenn jemand in einem unserer Wikis eine bestimmte Bild-Datei ...

VB for Applications
VBA Script - Pfade zu Dokumentevorlagen anpassen
gelöst Frage von JuckieVB for Applications11 Kommentare

Guten Morgen an alle, wir haben unser zentrales Dokumentenverzeichnis auf einen anderen Server umgezogen. Nun befinden sich in dem ...

Neue Wissensbeiträge
Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 6 StundenViren und Trojaner1 Kommentar

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 10 StundenRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Internet

Was nützt HTTPS, wenn es auch von Phishing Web-Seiten genutzt wird

Information von Penny.Cilin vor 3 TagenInternet17 Kommentare

HTTPS richtig einschätzen Ob man eine Webseite via HTTPS aufruft, zeigt ein Schloss neben der Adresse im Webbrowser an. ...

Webbrowser

Bugfix für Firefox Quantum released - Installation erfolgt teilweise nicht automatisch!

Erfahrungsbericht von Volchy vor 4 TagenWebbrowser8 Kommentare

Hallo zusammen, gem. dem Artike von heise online wurde mit VersionFirefox 57.0.1 sicherheitsrelevante Bugs behoben. Entgegen der aktuellen Veröffentlichung ...

Heiß diskutierte Inhalte
Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...

Voice over IP
Telefonstörung - Ortsrufnummern kein Verbindungsaufbau
Frage von Windows10GegnerVoice over IP10 Kommentare

Hallo, sowohl bei uns als auch beim Opa ist es über VoIP nicht möglich Ortsrufnummern anzurufen. Es kommt nach ...

Vmware
DOS 6.22 in VMWare mit CD-ROM
gelöst Frage von hesperVmware8 Kommentare

Hallo zusammen! Ich hab ein saublödes Problem. Es ist eine VMWare mit DOS 6.22 zu erstellen auf dem ein ...

Cloud-Dienste
PIM als SaaS Nutzungsgebühr
Frage von vanTastCloud-Dienste8 Kommentare

Moin, wir haben uns ein PIM (Product Information Management) nach unseren Ansprüchen für viel Geld als SaaS-Lösung bauen lassen. ...