Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Frage Entwicklung C und C++

Mitglied: Kariya

Kariya (Level 1) - Jetzt verbinden

27.12.2012 um 09:48 Uhr, 1959 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
Datenbanken
Access 2016 vertauscht Monat und Tag in meiner CSV Datei (1)

Frage von iGordon zum Thema Datenbanken ...

Batch & Shell
gelöst Auslesen und Vergleichen Zweiter CSV Dateien Powershell (7)

Frage von Hainoon zum Thema Batch & Shell ...

Batch & Shell
gelöst Powershell: ActiveDirectory Infos mit export-csv exportieren und formatieren (2)

Frage von MuHMuH zum Thema Batch & Shell ...

Neue Wissensbeiträge
Google Android

Cyanogenmod alternative Downloadquelle

(2)

Tipp von Lochkartenstanzer zum Thema Google Android ...

Batch & Shell

Batch als Dienst bei Systemstart ohne Anmeldung ausführen

(4)

Tipp von tralveller zum Thema Batch & Shell ...

Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

(1)

Tipp von gdconsult zum Thema Sicherheits-Tools ...

Heiß diskutierte Inhalte
Windows 7
gelöst Lokales Adminprofil defekt (25)

Frage von Yannosch zum Thema Windows 7 ...

Server
gelöst Wie erkennen, dass nur deutsche IPs Zugang zu einer Website haben? (22)

Frage von Coreknabe zum Thema Server ...

LAN, WAN, Wireless
gelöst Statische Routen mit ISC-DHCP Server für Android Devices (22)

Frage von terminator zum Thema LAN, WAN, Wireless ...

Exchange Server
gelöst Migration Exchange 2007 zu 2013 - Public Folder teilweise weg (16)

Frage von Andy1987 zum Thema Exchange Server ...