Galileo Computing < openbook > Galileo Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort zur 5. Auflage
1 Allgemeine Einführung in .NET
2 Grundlagen der Sprache C#
3 Klassendesign
4 Vererbung, Polymorphie und Interfaces
5 Delegates und Ereignisse
6 Weitere .NET-Datentypen
7 Weitere Möglichkeiten von C#
8 Auflistungsklassen (Collections)
9 Fehlerbehandlung und Debugging
10 LINQ to Objects
11 Multithreading und die Task Parallel Library (TPL)
12 Arbeiten mit Dateien und Streams
13 Binäre Serialisierung
14 Einige wichtige .NET-Klassen
15 Projektmanagement und Visual Studio 2010
16 XML
17 WPF – Die Grundlagen
18 WPF-Containerelemente
19 WPF-Steuerelemente
20 Konzepte der WPF
21 Datenbindung
22 2D-Grafik
23 ADO.NET – verbindungsorientierte Objekte
24 ADO.NET – Das Command-Objekt
25 ADO.NET – Der SqlDataAdapter
26 ADO.NET – Daten im lokalen Speicher
27 ADO.NET – Aktualisieren der Datenbank
28 Stark typisierte DataSets
29 LINQ to SQL
30 Weitergabe von Anwendungen
Stichwort

Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Visual C# 2010 von Andreas Kühnel
Das umfassende Handbuch
Buch: Visual C# 2010

Visual C# 2010
geb., mit DVD
1295 S., 49,90 Euro
Rheinwerk Computing
ISBN 978-3-8362-1552-7
Pfeil 14 Einige wichtige .NET-Klassen
Pfeil 14.1 Die Klasse »Object«
Pfeil 14.1.1 Referenzvergleiche mit »Equals« und »ReferenceEquals«
Pfeil 14.1.2 »ToString« und »GetType«
Pfeil 14.1.3 Die Methode »MemberwiseClone«
Pfeil 14.2 Die Klasse »String«
Pfeil 14.2.1 Erzeugen eines Strings
Pfeil 14.2.2 Eigenschaften von »String«
Pfeil 14.2.3 Methoden der Klasse »String«
Pfeil 14.2.4 Zusammenfassung der Klasse »String«
Pfeil 14.3 Die Klasse »StringBuilder«
Pfeil 14.3.1 Allgemeines
Pfeil 14.3.2 Kapazität eines »StringBuilder«-Objekts
Pfeil 14.3.3 Konstruktoren der Klasse »StringBuilder«
Pfeil 14.3.4 Eigenschaften der Klasse »StringBuilder«
Pfeil 14.3.5 Die Methoden der Klasse »StringBuilder«
Pfeil 14.3.6 Allgemeine Anmerkungen
Pfeil 14.4 Der Typ »DateTime«
Pfeil 14.4.1 Zeitspanne »Tick«
Pfeil 14.4.2 Konstruktoren von »DateTime«
Pfeil 14.4.3 Eigenschaften von »DateTime«
Pfeil 14.4.4 Methoden der Klasse »DateTime«
Pfeil 14.5 Die Klasse »TimeSpan«
Pfeil 14.6 Ausgabeformatierung
Pfeil 14.6.1 Formatierung mit der Methode »String.Format«
Pfeil 14.6.2 Formatierung mit der Methode »ToString«
Pfeil 14.6.3 Benutzerdefinierte Formatierung


Galileo Computing - Zum Seitenanfang

14.6 Ausgabeformatierung Zur nächsten ÜberschriftZur vorigen Überschrift

Zur Formatierung einer Ausgabe stehen Ihnen zwei Möglichkeiten zur Verfügung:

  • die statische Methode Format der Klasse String
  • die Methode ToString der Schnittstelle IFormatable

Galileo Computing - Zum Seitenanfang

14.6.1 Formatierung mit der Methode »String.Format« Zur nächsten ÜberschriftZur vorigen Überschrift

Rufen wir uns zuerst in Erinnerung, wie die Ausgabe der Methode DateTime.Now an der Konsole lautet:


Console.WriteLine(DateTime.Now.ToString());

Es wird das Datum einschließlich der Uhrzeit angezeigt:


17.09.2003 20:51:56

Mit der Format-Methode können wir eine andere, individuell passendere Ausgabe erzwingen:


Console.WriteLine(String.Format("{0:F}", DateTime.Now));

Damit würde die Anzeige wie folgt lauten:


Mittwoch, 17. September 2003 20:51:56

Es bietet sich auch die Möglichkeit an, mit


Console.WriteLine(String.Format("{0:D}", DateTime.Now));

auf die Zeitangabe ganz zu verzichten.

Formatierungsvarianten

Die einfachsten Varianten der überladenen Format-Methode lauten:


public static string Format(string format, object arg);
public static string Format(string format, params object[] args);

Der erste Parameter beschreibt eine Zeichenfolge mit einem oder mehreren Formatierungsausdrücken, die in geschweiften Klammern angegeben werden. Dem zweiten Parameter werden die zu formatierenden Objekte übergeben. Die Syntax erinnert sofort an die Formatierungen der Methode Console.WriteLine, die sich tatsächlich intern der Format-Methode bedient.

Unter den weiteren vier Überladungen ist eine besonders hervorzuheben, mit der festgelegt werden kann, welche Sprache bzw. Kultur für die Formatierung verwendet werden soll:


public static string Format(IFormatProvider provider,
                            string format, params object[] args);

Im ersten Parameter erwartet die Methode String.Format nun ein Objekt, das die Schnittstelle IFormatProvider implementiert. Im .NET Framework sind das drei Klassen:

  • CultureInfo
  • DateTimeFormatInfo
  • NumberFormatInfo

Diese Klassen gehören alle zum Namespace System.Globalization. Die Klasse CultureInfo stellt Informationen über eine bestimmte Kultur bereit, einschließlich des Schriftsystems sowie des verwendeten Kalenders. DateTimeFormatInfo definiert die Anzeige von Datum und Uhrzeit und NumberFormatInfo die Darstellung numerischer Werte – immer abhängig von der jeweiligen Kultur.

Um beispielsweise das aktuelle Systemdatum in italienischer Sprache auszugeben, müssen Sie nur ein entsprechendes CultureInfo-Objekt bereitstellen, das die italienische Kultur beschreibt:


CultureInfo culture = new CultureInfo("it-IT");
Console.WriteLine(String.Format(culture, "{0:D}", DateTime.Now)); 
// Ausgabe: sabato 20 settembre 2003

Mit den Eigenschaften DateTimeFormat und NumberFormat der Klasse CultureInfo kann das Ausgabeformat der spezifischen Kultur abgefragt und sogar neu festgelegt werden. Dazu veröffentlichen die beiden Klassen DateTimeFormatInfo und NumberFormatInfo eine größere Anzahl Eigenschaften. Wie Sie das Dezimaltrennzeichen einer gegebenen Kultur abweichend vom Standard spezifisch festlegen können, zeigt das folgende Codefragment:


double dbl = 12.25;
CultureInfo culture = new CultureInfo("de-DE");
NumberFormatInfo nfi = culture.NumberFormat;
nfi.NumberDecimalSeparator = "*";
Console.WriteLine(String.Format(culture, "{0}", dbl));

Es wird zuerst ein CultureInfo-Objekt erzeugt, das mit de-DE die deutsche Kultur beschreibt. Über dessen Eigenschaft NumberFormat wird die dazu entsprechende Referenz auf NumberFormatInfo ermittelt. Der Eigenschaft NumberDecimalSeparator wird anschließend das Zeichen * als neues Dezimaltrennzeichen zugewiesen.

Es kann sich als nützlich erweisen, ein kulturunabhängiges Format zur Verfügung zu stellen. Dieses erhalten Sie mit der statischen Eigenschaft InvariantCulture der Klasse CultureInfo. Das zurückgegebene CultureInfo-Objekt ist der englischen Sprache zugeordnet, ohne dabei landesspezifische Unterschiede zu berücksichtigen.

Standardformatzeichen der Klasse »NumberFormatInfo«

In Tabelle 14.8 sind die Standardformatzeichen für die einzelnen Standardmuster der NumberFormatInfo-Klasse aufgeführt. Teilweise können die Standardmuster auch durch Eigenschaften verändert werden. Genauere Informationen dazu entnehmen Sie bitte der .NET-Dokumentation zu der Klasse.


Tabelle 14.8 Formatzeichen der Methode »String.Format«

Formatzeichen Beschreibung

C oder c

Ausgabe im Währungsformat (einschließlich des Währungssymbols der aktuellen Ländereinstellung)

D oder d

Wird nur von ganzzahligen Datentypen unterstützt. Durch das Anhängen einer Zahl kann spezifiziert werden, wie viele Stellen die auszugebende Zahlenfolge aufweisen soll. Fehlende Ziffern werden mit Nullen aufgefüllt.

E oder e

Ausgabe im Exponentialformat

F oder f

Hängt an das Ende einer Zahl Dezimalstellen an. Die Anzahl der Nachkommastellen kann hinter dem Formatspezifizierer angegeben werden. Der Standard sind zwei Stellen.

G oder g

Allgemein formatierte Ausgabe

N oder n

Die Ausgabe erfolgt im Format ddd.ddd.ddd,dd.

P oder p

Ausgabe als Prozentzahl

R oder r

Roundtrip-Format. Es wird sichergestellt, dass ein Zurückkonvertieren nicht zu Genauigkeitsverlusten führt.

X oder x

Ausgabe als Hexadezimalzahl (ausschließlich für Ganzzahlenformate)


Standardformatzeichen der Klasse »DateTimeFormatInfo«

In Tabelle 14.9 sind die wichtigsten Standardmuster zur Formatierung von Datum und Uhrzeit aufgezählt. Maßgeblich sind auch hier die Einstellungen unter Ländereinstellung. Wie schon die Standardformatmuster der Klasse NumberFormatInfo können Sie über Eigenschaften einige der Standardmuster nach eigenen Vorstellungen ändern. Weitere Informationen entnehmen Sie auch hier der .NET-Dokumentation.


Tabelle 14.9 Formatcodes für Datum und Uhrzeit

Formatzeichen Beschreibung

d

Kurzes Datum (22.09.2003)

D

Langes Datum (Montag, 22. September 2003)

f

Langes Datum, inklusive Zeitangabe

(Montag, 22. September 2003 22:30)

F

Langes Datum, inklusive langer Zeitangabe

(Montag, 22. September 2003 22:30:45)

g

Kurzes Datum, inklusive Zeitangabe

(22.09.2003 22:30)

G

Kurzes Datum, inklusive langer Zeitangabe

(22.09.2003 22:30:45)

M oder m

Tag und Monat (22 September)

R oder r

Datum nach dem Muster des RFC 1123

(Mon, 22 Sep 2003 22:30:45 GMT)

t

Kurze Zeitangabe (22:30)

T

Lange Zeitangabe (22:30:45)

Y oder y

Monat und Jahr (September 2003)


Dazu zwei Beispiele:


string str;
str = String.Format("{0:F}", DateTime.Now) 
// Ausgabe: Dienstag, 23. September 2003 12:12:55
str = String.Format("{0:M}", DateTime.Now) 
// Ausgabe: 23 September


Galileo Computing - Zum Seitenanfang

14.6.2 Formatierung mit der Methode »ToString« Zur nächsten ÜberschriftZur vorigen Überschrift

Von der Klasse Object erbt jede .NET-Klasse die parameterlose Methode ToString. Darüber hinaus werden sowohl von den numerischen Typen als auch von der Klasse String Überladungen angeboten, die direkt auf dem zu formatierenden Wert aufgerufen werden. Sie können sich die float-Zahl zum Beispiel mit


float d = 0.01985F;
Console.WriteLine(d.ToString("P"));

als Prozentzahl oder mit


float d = 123.505F;
Console.WriteLine(d.ToString("E"));

im Exponentialformat ausgeben lassen. Auch hier wird die Einstellung der aktuellen Kultur berücksichtigt. Sie können als Formatierungszeichenfolge alle Formatzeichen angeben, die in den Tabellen 12.9 und 12.10 aufgeführt sind. Die geschweiften Klammern sind nicht erforderlich. Um landesspezifische Ausgaben zu ermöglichen, können Sie auch ein IFormatProvider-Objekt übergeben.


public virtual string ToString(IFormatProvider);

Beachten Sie, dass die verschiedenen Datentypen unterschiedlich viele Überladungen von ToString zur Verfügung stellen.


Galileo Computing - Zum Seitenanfang

14.6.3 Benutzerdefinierte Formatierung topZur vorigen Überschrift

Zahlen und Zeichenfolgen

Über die vordefinierten Formate hinaus können Sie auch eigene Formatierungen festlegen. Dazu wird Ihnen von .NET eine Reihe von Formatzeichen bereitgestellt, um die Ausgabe von Ganz- und Dezimalzahlen sowie Zeichenfolgen nach eigenen Vorstellungen zu beeinflussen.


Tabelle 14.10 Formatzeichen für benutzerdefinierte Zahlen- und Zeichenformate

Formatzeichen Beschreibung

0

Die Zahl 0 dient als Platzhalter für eine Zahl. Nichtsignifikante Nullen werden durch die Zahl 0 dargestellt.

#

Die Zahl 0 dient als Platzhalter für eine Zahl. Nichtsignifikante Nullen werden durch Leerzeichen dargestellt.

.

Das erste .-Zeichen in der Formatzeichenfolge bestimmt die Position des Dezimaltrennzeichens im formatierten Wert.

,

Dient als Tausendertrennung. Jedes Auftreten des Zeichens bewirkt eine Division durch 1000.

%

Das Zeichen bewirkt die Multiplikation mit 100. Das Prozentzeichen wird angehängt.

E0, E+0, E-0,
e0
, e+0, e-0

Die Codes bewirken die Exponentialdarstellung einer Zahl. Mit E+0 und e+0 wird das positive Vorzeichen immer angezeigt, mit allen anderen immer nur das negative. Die Anzahl der Nullen bestimmt die Mindestanzahl von Ziffern des Exponenten.

\

Das folgende Zeichen in der Formatzeichenfolge wird als Escape-Sequenz interpretiert.

ABC

Die in Anführungszeichen stehenden Zeichen werden direkt in die Ergebniszeichenfolge kopiert.


Nachfolgend wird an einigen Beispielen gezeigt, wie die Formatzeichen eingesetzt werden und zu welchem Ergebnis die Anweisungen führen:


double d = 12345.67890;
string str = d.ToString("000");    // Ausgabe: 12346
str = d.ToString("0000000");       // Ausgabe: 00123456
str = d.ToString("###");           // Ausgabe: 12346
str = d.ToString("#,#####");       // Ausgabe: 12.346
str = d.ToString("#.##");          // Ausgabe: 12345,68
str = d.ToString("#.#####");       // Ausgabe: 12345,6789
str = d.ToString("000e+000");      // Ausgabe: 123e+002
str = d.ToString("0%");            // Ausgabe: 1234568%

Datums- und Zeitangaben

Wenn Sie wollen, können Sie mit vordefinierten Codes eigene Mustervorgaben zur Darstellung des Datums und der Uhrzeit festlegen. Die Codes werden von der Klasse DateTimeFormatInfo bereitgestellt.


str = DateTime.Now.ToString("MMM/yyyy/dd");  
// Ausgabe: Sep.2004.12
str = DateTime.Now.ToString("HH:mm:ss");
// Ausgabe: 09:22:30


Tabelle 14.11 Formatzeichen für benutzerdefinierte Datums- und Zeitformate

Formatmuster Beschreibung

d

Monatstag ohne führende Null (1–31)

dd

Monatstag mit führender Null (01–31)

ddd

Abkürzung des Wochentags (Mon)

dddd

Vollständiger Name des Wochentags (Montag)

M

Monat ohne führende Null (1–12)

MM

Monat mit führender Null (01–12)

MMM

Abkürzung des Monatsnamens (Jan)

MMMM

Vollständiger Monatsname (Januar)

y

Zweistellige Jahreszahl ohne führende Null (3)

yy

Zweistellige Jahreszahl mit führender Null (03)

yyyy

Vollständige Jahreszahl (2003)

gg

Angabe der Zeitära

h

Stundenangabe in 12-Stunden-Schreibweise ohne führende Null

hh

Stundenangabe in 12-Stunden-Schreibweise mit führender Null

H

Stundenangabe in 24-Stunden-Schreibweise ohne führende Null

HH

Stundenangabe in 24-Stunden-Schreibweise mit führender Null

m

Minutenangabe ohne führende Null (0–59)

mm

Minutenangabe mit führender Null (00–59)

s

Sekundenangabe ohne führende Null (0–59)

ss

Sekundenangabe mit führender Null (0–59)

fffffff

Angabe von Sekundenbruchteilen

t

Das erste Zeichen des AM/PM-Kennzeichners (A entspricht AM, P entspricht PM.)

tt

AM oder PM

z

Zeitzonenangabe (+ oder –, gefolgt von der Stundenangabe; ohne führende Null)

zz

Zeitzonenangabe (+ oder –, gefolgt von der Stundenangabe; mit führender Null)

zzz

Vierstellige Zeitzonenangabe

/

Es wird das Standardtrennzeichen für Datumsangaben eingesetzt.

:

Es wird das Standardtrennzeichen für Zeitangaben eingesetzt.




Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen. >> Zum Feedback-Formular
<< zurück
  Zum Katalog
Zum Katalog: Visual C# 2010

Visual C# 2010
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Buchempfehlungen
Zum Katalog: Professionell entwickeln mit Visual C# 2012






 Professionell
 entwickeln mit
 Visual C# 2012


Zum Katalog: Windows Presentation Foundation






 Windows Presentation
 Foundation


Zum Katalog: Schrödinger programmiert C++






 Schrödinger
 programmiert C++


Zum Katalog: C++ Handbuch






 C++ Handbuch


Zum Katalog: C/C++






 C/C++


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Rheinwerk Verlag GmbH 2010
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das <openbook> denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.


Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern