AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

writeln für excel

Ein Thema von danieldelphi · begonnen am 24. Mär 2015 · letzter Beitrag vom 24. Mär 2015
Antwort Antwort
Seite 2 von 3     12 3      
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#11

AW: writeln für excel

  Alt 24. Mär 2015, 11:28
Zellentrenner <> Zeilentrenner
Einen Zeilenumbrung innerhalb einer Zelle: #A
Eine neue Zeile: #D#A bzw. linebreak oder WriteLn() pro Zeile
Markus Kinzler
  Mit Zitat antworten Zitat
noisy_master

Registriert seit: 17. Jun 2009
Ort: Wolfenbüttel/Baddeckenstedt
257 Beiträge
 
Delphi XE5 Professional
 
#12

AW: writeln für excel

  Alt 24. Mär 2015, 11:29
Moin,

es gibt bei Excel keinen "Separator" für die Zeilen. um mehrere Zeilen in Excel als csv zu Importieren brauchst du mehrere writeln's. Der Separator ist dazu da, um die Spalten voneinander zu trennen.

Welchen Excel dafür verwenden soll kannst du in der 1. Zeile im csv angeben mit sep=Trennzeichen


So sollte es also funktionieren:

Delphi-Quellcode:
writeln(f,'sep=;'); //Excel soll ; als Trennzeichen zwischen Spalten benutzen
writeln(f,'Zeile1_Spalte1;Zeile1_Spalte2;Zeile1_Spalte3'); //1.Zeile
writeln(f,'Zeile2_Spalte1;Zeile2_Spalte2;Zeile2_Spalte3'); //2.Zeile
.
.
.
Dirk
  Mit Zitat antworten Zitat
bcvs

Registriert seit: 16. Jun 2011
668 Beiträge
 
Delphi 12 Athens
 
#13

AW: writeln für excel

  Alt 24. Mär 2015, 11:31
Du suchst also das Trennzeichen, das Excel verwendet, wenn man z.B. im Explorer eine csv-Datei doppelklickt und nicht in Excel über den Textkonvertierungs-Assistenten geht.

Bei mir ist das ;

Probiers hat einfach mal aus.
Die üblichen Verdächtigen sind , ; und Tabulator (#9)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#14

AW: writeln für excel

  Alt 24. Mär 2015, 11:53
EDIT Der TE will tatsächlich in die nächste ZELLE schreiben - meine Augen werden alt
Zitat von Blödsinn von mir:
mkinzler hat es als Einziger verstanden

Der TE möchte, dass der Wert in der nächsten ZEILE und nicht in der nächsten ZELLE erscheint.

Dabei ist das ganz einfach, wenn etwas in die nächsten ZEILE soll, dann schreibe ich einfach eine neue Zeile
Delphi-Quellcode:
// Schreibe in ZWEI Zeilen
WriteLn( 'Zeile 1 - Spalte 1' );
WriteLn( 'Zeile 2 - Spalte 1' );
anstatt
Delphi-Quellcode:
// Schreibe in EINE Zeile
WriteLn( 'Zeile 1 - Spalte 1' + FormatSettings.ListSeparator + 'Zeile 1 - Spalte 2' );
Nur so nebenbei:

Delphi-Referenz durchsuchenFormatSettings.ListSeparator beinhaltet das Listentrennzeichen, was auch das lokal installierte Excel benutzt (das holt sich dieses Zeichen über den gleichen Weg -> Regionseinstellungen). Damit erübrigen sich die Verdächtigungen und auch jegliches Rätselraten.

Wer eine CSV-Datei an Empfänger versenden möchte, wo nicht klar ist, welche Landeseinstellungen die auf ihrem Rechner haben, so ist man gut beraten die CSV-Datei mit einer passenden Bei Google suchenschema.ini zu versenden.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (24. Mär 2015 um 12:05 Uhr)
  Mit Zitat antworten Zitat
bcvs

Registriert seit: 16. Jun 2011
668 Beiträge
 
Delphi 12 Athens
 
#15

AW: writeln für excel

  Alt 24. Mär 2015, 12:05
Ich habe das schon auch verstanden. Der TE wusste ja nur nicht, welches Trennzeichen er nehmen soll.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#16

AW: writeln für excel

  Alt 24. Mär 2015, 12:06
mkinzler hat es als Einziger verstanden

Der TE möchte, dass der Wert in der nächsten ZEILE und nicht in der nächsten ZELLE erscheint.
Achja?
gibt es ein Zeichen, das Excel sagt es soll in dieser Zeile die nächste Zelle befüllen?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#17

AW: writeln für excel

  Alt 24. Mär 2015, 12:08
Ich habe das schon auch verstanden. Der TE wusste ja nur nicht, welches Trennzeichen er nehmen soll.
mkinzler hat es als Einziger verstanden

Der TE möchte, dass der Wert in der nächsten ZEILE und nicht in der nächsten ZELLE erscheint.
Achja?
gibt es ein Zeichen, das Excel sagt es soll in dieser Zeile die nächste Zelle befüllen?
Ich hatte es falsch gelesen (s. Edit) - als Trennzeichen für die Zellen nimmt man aber am sinnvollsten das aus der Regionseinstellung
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
danieldelphi

Registriert seit: 12. Mär 2015
38 Beiträge
 
#18

AW: writeln für excel

  Alt 24. Mär 2015, 12:12
Ich habe das schon auch verstanden. Der TE wusste ja nur nicht, welches Trennzeichen er nehmen soll.
mkinzler hat es als Einziger verstanden

Der TE möchte, dass der Wert in der nächsten ZEILE und nicht in der nächsten ZELLE erscheint.
Achja?
gibt es ein Zeichen, das Excel sagt es soll in dieser Zeile die nächste Zelle befüllen?
Ich hatte es falsch gelesen (s. Edit) - als Trennzeichen für die Zellen nimmt man aber am sinnvollsten das aus der Regionseinstellung
super danke! ich denke damit krieg ich es hin! vielen dank!
  Mit Zitat antworten Zitat
danieldelphi

Registriert seit: 12. Mär 2015
38 Beiträge
 
#19

AW: writeln für excel

  Alt 24. Mär 2015, 12:12
Echt Klasse diese Forum hier!
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#20

AW: writeln für excel

  Alt 24. Mär 2015, 12:26
Könnte mal jemand das für mich erklären?
geht es darum innerhalb einer Zelle in die nächste Zeile zu kommen oder soll eine neue ZellenZeile aufgemacht werden?

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine 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 aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:59 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz