AGB  ·  Datenschutz  ·  Impressum  







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

Excel: Zelle als "Text" formatieren

Ein Thema von Helmi · begonnen am 10. Sep 2013 · letzter Beitrag vom 11. Sep 2013
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.312 Beiträge
 
Delphi XE2 Professional
 
#1

Excel: Zelle als "Text" formatieren

  Alt 10. Sep 2013, 19:43
Hallo,

wie kann ich eine Excel-Zelle als "Text" formatieren?
Leider finde ich im Forum nur Datumsformatierungen

Schreiben tu ich so in die Excel-Datei:
http://www.delphipraxis.net/171539-e...cel-datei.html
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: Excel: Zelle als "Text" formatieren

  Alt 10. Sep 2013, 20:46
Delphi-Quellcode:
   
    excel.activesheet.cells(1,j+1).EntireColumn.NumberFormat:='@';
    excel.activesheet.EntireColumn.Cells(1,2).NumberFormat:= '@';
    excel.activesheet.cells(1,j+1).NumberFormat:='@';
    excel.activesheet.Cells.NumberFormat := '@';
Es gibt mehrere Möglichkeiten, probier's mal aus.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Aviator

Registriert seit: 3. Jun 2010
1.610 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: Excel: Zelle als "Text" formatieren

  Alt 10. Sep 2013, 20:48
Hallo Helmi,

hatte mir mal eine Funktion geschrieben um immer die entsprechende Formatierung zu erhalten.

Delphi-Quellcode:
function GetFieldDataType(QueryField: TField): Ansistring;
  const
    FORMAT_GENERAL = 'General';
    FORMAT_STANDARD = 'Standard';
    FORMAT_TEXT = '@';
    FORMAT_DEZIMAL = '0.00';
    FORMAT_INTEGER = '0';
    FORMAT_DATE = 'dd.mm.yyyy';
    FORMAT_DATETIME = 'dd.mm.yyyy hh:mm:ss';
    FORMAT_CURRENCY = '$#,##0.00_);[Red]($#,##0.00)';
    FORMAT_TIME = 'hh:mm:ss';

  begin
  //if QueryField.FieldName = 'Gesamtsumme' then ShowMessage(TMTools.FieldTypeToStr(QueryField.DataType));
    case QueryField.DataType of
      ftUnknown: Result := FORMAT_TEXT;
      ftAutoInc: Result := FORMAT_INTEGER;
      ftString: Result := FORMAT_TEXT;
      ftSmallint: Result := FORMAT_DEZIMAL;
      ftInteger: Result := FORMAT_INTEGER;
      ftWord: Result := FORMAT_STANDARD;
      ftBoolean: Result := FORMAT_TEXT;
      ftFloat: Result := FORMAT_DEZIMAL;
      ftCurrency: Result := FORMAT_CURRENCY;
      ftDate: Result := FORMAT_DATE;
      ftDateTime: Result := FORMAT_DATETIME;
      ftMemo: Result := FORMAT_TEXT;
      ftWideMemo: Result := FORMAT_TEXT;
      ftBCD: Result := FORMAT_INTEGER;
      ftTime: Result := FORMAT_TIME;
      else Result := FORMAT_TEXT;
    end;
  end;
Hat bisher immer funktioniert.
Text also mit @ formatieren. Und immer daran denken, die Formatierung auszuführen bevor du die Zelle füllst.

Ein Aufruf könnte dann so aussehen:

Delphi-Quellcode:
Excel.Sheets[TableName].Cells[Zeile, Spalte].NumberFormat := GetFieldDataType(SourceQuery.Fields[I]);
Excel.Sheets[TableName].Cells[Zeile, Spalte].Value := SourceQuery.Fields[I].AsString;
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.312 Beiträge
 
Delphi XE2 Professional
 
#4

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 15:51
Hallo,

Danke für die Antworten.

Ich habe jetzt:
Excel.ActiveSheet.Cells[Zeile, 3].NumberFormat := '@'; .

Schau ich mir dann in Excel die Formatierung der Zelle an, so ist "benutzerdefiniert" aktiv
und nicht Text. Geht das nicht anders, oder fehlt noch etwas?
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 16:36
Soweit ich weiß, ist alles was nicht von Excel kommt "Benutzerdefiniert".

Aber wie Aviator schrieb "hat bisher immer funktioniert"

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.312 Beiträge
 
Delphi XE2 Professional
 
#6

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 16:59
bei mir leider nicht

ich übergebe einer Zelle den Text "4:" - in Excel steht dann in der Zelle "64"
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
662 Beiträge
 
#7

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 18:37
ich übergebe einer Zelle den Text "4:" - in Excel steht dann in der Zelle "64"
Ach, das kenn ich: Vor allem wenn vorher alles lief, man das Projekt dann von Delphi 7 auf 2009 umstellt, man selber natürlich nichts bemerkt und der Kunde am Telefon plötzlich etwas von "alles 64" erzählt

Ein
Code:
... := AnsiChar('@');
schafft aber Abhilfe.
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.312 Beiträge
 
Delphi XE2 Professional
 
#8

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 18:49
Vielen Dank!
Mit AnsiChar funktioniert das Ganze und im Excel wird das Format "Text" angezeigt!
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Aviator

Registriert seit: 3. Jun 2010
1.610 Beiträge
 
Delphi 10.3 Rio
 
#9

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 21:10
Also der Rückgabetyp meiner Funktion ist Ansistring. Das man das @ als Char übergeben kann ist ja dann eigentlich das selbe (denke ich zumindest).
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.312 Beiträge
 
Delphi XE2 Professional
 
#10

AW: Excel: Zelle als "Text" formatieren

  Alt 11. Sep 2013, 21:15
Also der Rückgabetyp meiner Funktion ist Ansistring. Das man das @ als Char übergeben kann ist ja dann eigentlich das selbe (denke ich zumindest).
sorry - hab ich übersehen!
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 07:01 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