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

Header in csv einfügen

Mitglied: Kariya

Kariya (Level 1) - Jetzt verbinden

27.12.2012 um 09:48 Uhr, 1982 Aufrufe, 1 Kommentar

Ich habe ein Programm, welches Daten aus einer csv abgleicht und unter bestimmten Bedingungen in eine neue csv einfügt.
Leider bekomme ich es nicht hin, dass der neuen csv ein Header geschrieben wird.
Der Quellcode sieht wie folgt aus:

01.
 using System; 
02.
using System.Collections.Generic; 
03.
using System.IO; 
04.
using System.Linq; 
05.
using System.Net; 
06.
using System.Text; 
07.
using System.Text.RegularExpressions; 
08.
 
09.
namespace CsvMerge 
10.
11.
	public static class Program 
12.
13.
		public static void Main() 
14.
15.
            // ignorierte Artikelnummer holen 
16.
            string[] filteredArticles = File.ReadAllLines("Artikelfilter.txt",Encoding.Default); 
17.
 
18.
			// alle verfügbaren (Bild-)Dateien vom FTP-Server holen 
19.
			List<string> availableImages = Program.GetFtpFiles().ToList(); 
20.
 
21.
			// die Zeilen aus allen CSV-Dateien laden 
22.
			IEnumerable<List<string>> allCsvRows = Program.GetCsvRows(); 
23.
 
24.
			// alle Zeilen durchlaufen und der Ergebnisliste hinzufügen, wenn es ein Bild zum Artikel gibt 
25.
			List<List<string>> result = new List<List<string>>(); 
26.
            foreach (List<string> row in allCsvRows) 
27.
28.
                string artikelNr = row[1]; 
29.
                if (availableImages.Contains(artikelNr + ".jpg", StringComparer.InvariantCultureIgnoreCase)) 
30.
                    row[21] = "http://coxx.it/pictures/" + artikelNr + ".jpg"; 
31.
 
32.
                // nur Zeilen übernehmen mit Bild und nicht rausgefilterten Artikelnummern 
33.
                if (!String.IsNullOrEmpty(row[21]) && !filteredArticles.Contains(artikelNr)) 
34.
                    result.Add(row); 
35.
36.
 
37.
			// wieder CSV-Zeilen erstellen 
38.
			string[] resultLines = result 
39.
				.Select(cells => String.Join(";",cells.Select(value => "\"" + value.Replace("\"","\\\"") + "\"").ToArray())) 
40.
				.ToArray(); 
41.
 
42.
			// CSV-Datei erstellen 
43.
			string fileName = "merged.csv"; 
44.
			File.Delete(fileName); 
45.
			File.WriteAllLines(fileName,resultLines,Encoding.Default); 
46.
 
47.
			// CSV-Datei hochladen 
48.
			WebClient webClient = new WebClient(); 
49.
			webClient.Credentials = new NetworkCredential("Login1","Password"); 
50.
			webClient.UploadFile("FTP-Server"+fileName,fileName); 
51.
52.
 
53.
 
54.
		private static IEnumerable<string> GetFtpFiles() 
55.
56.
			WebRequest webRequest = WebRequest.Create("FTP-Server"); 
57.
			webRequest.Credentials = new NetworkCredential("Login2","Password"); 
58.
			webRequest.Method = WebRequestMethods.Ftp.ListDirectory; 
59.
 
60.
			using (WebResponse webResponse = webRequest.GetResponse()) 
61.
			using (Stream responseStream = webResponse.GetResponseStream()) 
62.
			using (StreamReader streamReader = new StreamReader(responseStream)) 
63.
				while (!streamReader.EndOfStream) 
64.
					yield return streamReader.ReadLine(); 
65.
66.
 
67.
 
68.
		private static IEnumerable<List<string>> GetCsvRows() 
69.
70.
			foreach (string file in Directory.GetFiles(@"E:\FTP","*.csv")) 
71.
72.
				string[] content = File.ReadAllLines(file,Encoding.Default); 
73.
				foreach (string line in content) 
74.
					yield return Regex.Matches(line,@"""(?<cell>.*?)(?<!\\)"",?").Cast<Match>().Select(match => match.Groups["cell"].Value).ToList(); 
75.
76.
77.
78.
}
Mitglied: nxclass
28.12.2012 um 15:13 Uhr
Bin kein C Entwickler - aber CSV Dateien sind simple Textdateien OHNE Encoding. Wenn Du nun Daten exportieren/importieren willst musst Du in der Spec festlegen welches Encoding die CSV Daten haben sollen.
Bitte warten ..
Ähnliche Inhalte
Microsoft Office

Excell - CSV Dateien aus Ordner in eine Workmap einfügen VBA

Frage von 134094Microsoft Office5 Kommentare

Hallo Forum, ich habe folgendes Problem: Ich habe eine Menge CSV-Dateien die ich in einer Excelltabelle darstellen will. Für ...

Batch & Shell

Per Batch eine Spalte in eine CSV Datei einfügen

gelöst Frage von mayli01Batch & Shell13 Kommentare

Hallo Forum :) Folgende Ausgangssituation. Ich habe eine CSV Artikelliste mit insgesamt 9 Spalten, einer Kopfzeile und etwa 50 ...

Exchange Server

Ungültiger header

Frage von HeinrichMExchange Server2 Kommentare

Hallo zusammen, hier auf einem SBS 2011 gibt es von Zeit zu Zeit Probleme mit dem POP Abruf vom ...

Microsoft

PowerShell: CSV in CSV kopieren

gelöst Frage von PludanMicrosoft3 Kommentare

Hallo Ich bin an einem PS Skript dran der den Inhalt von CSV 1 in CSV 2 kopiert. Wie ...

Neue Wissensbeiträge
Windows 10

Neue Sicherheitslücke in Windows 10 (Version 1709) durch Google öffentlich geworden

Information von kgborn vor 9 StundenWindows 10

Vor ein paar Tagen haben Googles Sicherheitsforscher vom Projekt Zero eine Sicherheitslücke im Edge-Browser publiziert. Jetzt wurde eine weitere ...

iOS
IOS 11.2.6 verfügbar
Information von sabines vor 14 StundeniOS

Mit dem Update soll der Bug behoben werden, bei dem eine bestimmte Zeichenkette IOS zum Absturz gebracht hat.

Sicherheit
Sicherheitsrisiko: Die Krux mit 7-Zip
Information von kgborn vor 1 TagSicherheit8 Kommentare

Bei vielen Anwendern ist das Tool 7-Zip zum Entpacken von Archivdateien im Einsatz. Die Software ist kostenlos und steht ...

Internet

Datendealing im WWW Tracking Methoden immer brutaler

Information von sabines vor 1 TagInternet

Interessanter Artikel zum Thema Tracking im WWW und die immer "besseren" Methoden des Trackings. Professor Arvind Narayanan (Princeton-Universität) betreibt ...

Heiß diskutierte Inhalte
Router & Routing
LANCOM VPN CLIENT einrichten
Frage von Finchen961988Router & Routing27 Kommentare

Hallo, ich habe ein Problem und hoffe ihr könnt mir helfen, wir haben einen Kunden der hat einen Speedport ...

Windows Server
AD DS findet Domäne nicht, behebbar?
Frage von schapitzWindows Server25 Kommentare

Guten Tag, ich habe bei einem Kunden ein Problem mit den AD DS. Umgebung ist folgende: Windows Server 2016 ...

LAN, WAN, Wireless
VPN Cisco ASA5505 PaloAlto PA-200
gelöst Frage von YannoschLAN, WAN, Wireless22 Kommentare

Hallo zusammen, ich würde gerne ein Site-to-Site VPN zwischen den beiden Standorten aufbauen. PaloAlto PA200 Internetanschluss Deutsche Telekom GK ...

Visual Studio
Singletone Objekt in Datei speichern
gelöst Frage von it4baerVisual Studio13 Kommentare

Hallo, ist es möglich ein Singleton-Objekt zu "serialisieren" und dann in eine Datei zu speichern um es später wieder ...