Movatterモバイル変換


[0]ホーム

URL:


ICU 78.1  78.1
Public Types |Public Member Functions |Static Public Member Functions |Protected Member Functions |Protected Attributes |Friends
icu::DateFormat Class Referenceabstract

DateFormat is an abstract class for a family of classes that convert dates and times from their internal representations to textual form and back again in a language-independent manner.More...

#include <datefmt.h>

Inheritance diagram for icu::DateFormat:

Public Types

enum  EStyle {
  kNone = -1,kFull = 0,kLong = 1,kMedium = 2,
  kShort = 3,kDateOffset = kShort + 1,kDateTime = 8,kDateTimeOffset = kDateTime + 1,
  kRelative = (1 << 7),kFullRelative = (kFull | kRelative),kLongRelative = kLong | kRelative,kMediumRelative = kMedium | kRelative,
  kShortRelative = kShort | kRelative,kDefault = kMedium,FULL = kFull,LONG = kLong,
  MEDIUM = kMedium,SHORT = kShort,DEFAULT = kDefault,DATE_OFFSET = kDateOffset,
  NONE = kNone,DATE_TIME = kDateTime
}
 Constants for various style patterns.More...
 
enum  EField {
  kEraField = UDAT_ERA_FIELD,kYearField = UDAT_YEAR_FIELD,kMonthField = UDAT_MONTH_FIELD,kDateField = UDAT_DATE_FIELD,
  kHourOfDay1Field = UDAT_HOUR_OF_DAY1_FIELD,kHourOfDay0Field = UDAT_HOUR_OF_DAY0_FIELD,kMinuteField = UDAT_MINUTE_FIELD,kSecondField = UDAT_SECOND_FIELD,
  kMillisecondField = UDAT_FRACTIONAL_SECOND_FIELD,kDayOfWeekField = UDAT_DAY_OF_WEEK_FIELD,kDayOfYearField = UDAT_DAY_OF_YEAR_FIELD,kDayOfWeekInMonthField = UDAT_DAY_OF_WEEK_IN_MONTH_FIELD,
  kWeekOfYearField = UDAT_WEEK_OF_YEAR_FIELD,kWeekOfMonthField = UDAT_WEEK_OF_MONTH_FIELD,kAmPmField = UDAT_AM_PM_FIELD,kHour1Field = UDAT_HOUR1_FIELD,
  kHour0Field = UDAT_HOUR0_FIELD,kTimezoneField = UDAT_TIMEZONE_FIELD,kYearWOYField = UDAT_YEAR_WOY_FIELD,kDOWLocalField = UDAT_DOW_LOCAL_FIELD,
  kExtendedYearField = UDAT_EXTENDED_YEAR_FIELD,kJulianDayField = UDAT_JULIAN_DAY_FIELD,kMillisecondsInDayField = UDAT_MILLISECONDS_IN_DAY_FIELD,ERA_FIELD = UDAT_ERA_FIELD,
  YEAR_FIELD = UDAT_YEAR_FIELD,MONTH_FIELD = UDAT_MONTH_FIELD,DATE_FIELD = UDAT_DATE_FIELD,HOUR_OF_DAY1_FIELD = UDAT_HOUR_OF_DAY1_FIELD,
  HOUR_OF_DAY0_FIELD = UDAT_HOUR_OF_DAY0_FIELD,MINUTE_FIELD = UDAT_MINUTE_FIELD,SECOND_FIELD = UDAT_SECOND_FIELD,MILLISECOND_FIELD = UDAT_FRACTIONAL_SECOND_FIELD,
  DAY_OF_WEEK_FIELD = UDAT_DAY_OF_WEEK_FIELD,DAY_OF_YEAR_FIELD = UDAT_DAY_OF_YEAR_FIELD,DAY_OF_WEEK_IN_MONTH_FIELD = UDAT_DAY_OF_WEEK_IN_MONTH_FIELD,WEEK_OF_YEAR_FIELD = UDAT_WEEK_OF_YEAR_FIELD,
  WEEK_OF_MONTH_FIELD = UDAT_WEEK_OF_MONTH_FIELD,AM_PM_FIELD = UDAT_AM_PM_FIELD,HOUR1_FIELD = UDAT_HOUR1_FIELD,HOUR0_FIELD = UDAT_HOUR0_FIELD,
  TIMEZONE_FIELD = UDAT_TIMEZONE_FIELD
}
 Field selector forFieldPosition forDateFormat fields.More...
 

Public Member Functions

virtualU_I18N_API ~DateFormat ()
 Destructor.More...
 
virtualU_I18N_APIDateFormatclone () const override=0
 Clones this object polymorphically.More...
 
virtualU_I18N_API bool operator== (constFormat &) const override
 Equality operator.More...
 
virtualU_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,FieldPosition &pos,UErrorCode &status) const override
 Format an object to produce a string.More...
 
virtualU_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,FieldPositionIterator *posIter,UErrorCode &status) const override
 Format an object to produce a string.More...
 
virtualU_I18N_APIUnicodeStringformat (Calendar &cal,UnicodeString &appendTo,FieldPosition &fieldPosition) const =0
 Formats a date into a date/time string.More...
 
virtualU_I18N_APIUnicodeStringformat (Calendar &cal,UnicodeString &appendTo,FieldPositionIterator *posIter,UErrorCode &status) const
 Formats a date into a date/time string.More...
 
U_I18N_APIUnicodeStringformat (UDate date,UnicodeString &appendTo,FieldPosition &fieldPosition) const
 Formats a UDate into a date/time string.More...
 
U_I18N_APIUnicodeStringformat (UDate date,UnicodeString &appendTo,FieldPositionIterator *posIter,UErrorCode &status) const
 Formats a UDate into a date/time string.More...
 
U_I18N_APIUnicodeStringformat (UDate date,UnicodeString &appendTo) const
 Formats a UDate into a date/time string.More...
 
virtualU_I18N_APIUDate parse (constUnicodeString &text,UErrorCode &status) const
 Parse a date/time string.More...
 
virtualU_I18N_API void parse (constUnicodeString &text,Calendar &cal,ParsePosition &pos) const =0
 Parse a date/time string beginning at the given parse position.More...
 
U_I18N_APIUDate parse (constUnicodeString &text,ParsePosition &pos) const
 Parse a date/time string beginning at the given parse position.More...
 
virtualU_I18N_API void parseObject (constUnicodeString &source,Formattable &result,ParsePosition &parse_pos) const override
 Parse a string to produce an object.More...
 
virtualU_I18N_APIUBool isLenient () const
 Returns whether both date/time parsing in the encapsulatedCalendar object andDateFormat whitespace & numeric processing is lenient.More...
 
virtualU_I18N_API void setLenient (UBool lenient)
 Specifies whether date/time parsing is to be lenient.More...
 
virtualU_I18N_APIUBool isCalendarLenient () const
 Returns whether date/time parsing in the encapsulatedCalendar object processing is lenient.More...
 
virtualU_I18N_API void setCalendarLenient (UBool lenient)
 Specifies whether encapsulatedCalendar date/time parsing is to be lenient.More...
 
virtualU_I18N_API constCalendargetCalendar () const
 Gets the calendar associated with this date/time formatter.More...
 
virtualU_I18N_API void adoptCalendar (Calendar *calendarToAdopt)
 Set the calendar to be used by this date format.More...
 
virtualU_I18N_API void setCalendar (constCalendar &newCalendar)
 Set the calendar to be used by this date format.More...
 
virtualU_I18N_API constNumberFormatgetNumberFormat () const
 Gets the number formatter which this date/time formatter uses to format and parse the numeric portions of the pattern.More...
 
virtualU_I18N_API void adoptNumberFormat (NumberFormat *formatToAdopt)
 Allows you to set the number formatter.More...
 
virtualU_I18N_API void setNumberFormat (constNumberFormat &newNumberFormat)
 Allows you to set the number formatter.More...
 
virtualU_I18N_API constTimeZonegetTimeZone () const
 Returns a reference to theTimeZone used by thisDateFormat's calendar.More...
 
virtualU_I18N_API void adoptTimeZone (TimeZone *zoneToAdopt)
 Sets the time zone for the calendar of thisDateFormat object.More...
 
virtualU_I18N_API void setTimeZone (constTimeZone &zone)
 Sets the time zone for the calendar of thisDateFormat object.More...
 
virtualU_I18N_API void setContext (UDisplayContext value,UErrorCode &status)
 Set a particular UDisplayContext value in the formatter, such as UDISPCTX_CAPITALIZATION_FOR_STANDALONE.More...
 
virtualU_I18N_APIUDisplayContext getContext (UDisplayContextType type,UErrorCode &status) const
 Get the formatter's UDisplayContext value for the specified UDisplayContextType, such as UDISPCTX_TYPE_CAPITALIZATION.More...
 
virtualU_I18N_APIDateFormatsetBooleanAttribute (UDateFormatBooleanAttribute attr,UBool newvalue,UErrorCode &status)
 Sets an boolean attribute on thisDateFormat.More...
 
virtualU_I18N_APIUBool getBooleanAttribute (UDateFormatBooleanAttribute attr,UErrorCode &status) const
 Returns a boolean from thisDateFormat May return U_UNSUPPORTED_ERROR if this instance does not support the specified attribute.More...
 
U_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,UErrorCode &status) const
 Formats an object to produce a string.More...
 
virtualU_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,FieldPosition &pos,UErrorCode &status) const=0
 Format an object to produce a string.More...
 
virtualU_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,FieldPositionIterator *posIter,UErrorCode &status) const
 Format an object to produce a string.More...
 
- Public Member Functions inherited fromicu::Format
virtualU_I18N_API ~Format ()
 Destructor.More...
 
U_I18N_API bool operator!= (constFormat &other) const
 Return true if the givenFormat objects are not semantically equal.More...
 
U_I18N_APIUnicodeStringformat (constFormattable &obj,UnicodeString &appendTo,UErrorCode &status) const
 Formats an object to produce a string.More...
 
U_I18N_API void parseObject (constUnicodeString &source,Formattable &result,UErrorCode &status) const
 Parses a string to produce an object.More...
 
U_I18N_APILocale getLocale (ULocDataLocaleType type,UErrorCode &status) const
 Get the locale for this format object.More...
 
U_I18N_API const char * getLocaleID (ULocDataLocaleType type,UErrorCode &status) const
 Get the locale for this format object.More...
 
- Public Member Functions inherited fromicu::UObject
virtual ~UObject ()
 Destructor.More...
 
virtualUClassID getDynamicClassID () const
 ICU4C "poor man's RTTI", returns a UClassID for the actual ICU class.More...
 

Static Public Member Functions

staticU_I18N_APIDateFormatcreateInstance ()
 Create a default date/time formatter that uses the SHORT style for both the date and the time.More...
 
staticU_I18N_APIDateFormatcreateTimeInstance (EStyle style=kDefault, constLocale &aLocale=Locale::getDefault())
 Creates a time formatter with the given formatting style for the given locale.More...
 
staticU_I18N_APIDateFormatcreateDateInstance (EStyle style=kDefault, constLocale &aLocale=Locale::getDefault())
 Creates a date formatter with the given formatting style for the given const locale.More...
 
staticU_I18N_APIDateFormatcreateDateTimeInstance (EStyle dateStyle=kDefault,EStyle timeStyle=kDefault, constLocale &aLocale=Locale::getDefault())
 Creates a date/time formatter with the given formatting styles for the given locale.More...
 
staticU_I18N_APIUnicodeString getBestPattern (constLocale &locale, constUnicodeString &skeleton,UErrorCode &status)
 Returns the best pattern given a skeleton and locale.More...
 
staticU_I18N_APIDateFormatcreateInstanceForSkeleton (constUnicodeString &skeleton,UErrorCode &status)
 Creates a date/time formatter for the given skeleton and default locale.More...
 
staticU_I18N_APIDateFormatcreateInstanceForSkeleton (constUnicodeString &skeleton, constLocale &locale,UErrorCode &status)
 Creates a date/time formatter for the given skeleton and locale.More...
 
staticU_I18N_APIDateFormatcreateInstanceForSkeleton (Calendar *calendarToAdopt, constUnicodeString &skeleton, constLocale &locale,UErrorCode &status)
 Creates a date/time formatter for the given skeleton and locale.More...
 
staticU_I18N_API constLocalegetAvailableLocales (int32_t &count)
 Gets the set of locales for which DateFormats are installed.More...
 

Protected Member Functions

U_I18N_API DateFormat ()
 Default constructor.More...
 
U_I18N_API DateFormat (constDateFormat &)
 Copy constructor.More...
 
U_I18N_APIDateFormatoperator= (constDateFormat &)
 Default assignment operator.More...
 
- Protected Member Functions inherited fromicu::Format
U_I18N_API void setLocaleIDs (const char *valid, const char *actual)
 
U_I18N_API Format ()
 Default constructor for subclass use only.More...
 
U_I18N_API Format (constFormat &)
 
U_I18N_APIFormatoperator= (constFormat &)
 

Protected Attributes

CalendarfCalendar
 The calendar thatDateFormat uses to produce the time field values needed to implement date/time formatting.More...
 
NumberFormatfNumberFormat
 The number formatter thatDateFormat uses to format numbers in dates and times.More...
 

Friends

class DateFmtKeyByStyle
 

Additional Inherited Members

- Static Protected Member Functions inherited fromicu::Format
staticU_I18N_API void syntaxError (constUnicodeString &pattern, int32_t pos,UParseError &parseError)
 Simple function for initializing aUParseError from aUnicodeString.More...
 

Detailed Description

DateFormat is an abstract class for a family of classes that convert dates and times from their internal representations to textual form and back again in a language-independent manner.

Converting from the internal representation (milliseconds since midnight, January 1, 1970) to text is known as "formatting," and converting from text to millis is known as "parsing." We currently define only one concrete subclass ofDateFormat:SimpleDateFormat, which can handle pretty much all normal date formatting and parsing actions.

DateFormat helps you to format and parse dates for any locale. Your code can be completely independent of the locale conventions for months, days of the week, or even the calendar format: lunar vs. solar.

To format a date for the currentLocale, use one of the static factory methods:

DateFormat* dfmt =DateFormat::createDateInstance();
UDate myDate =Calendar::getNow();
UnicodeString myString;
myString = dfmt->format( myDate, myString );
static U_I18N_API UDate getNow()
Returns the current UTC (GMT) time measured in milliseconds since 0:00:00 on 1/1/70 (derived from the...
U_I18N_API DateFormat()
Default constructor.
static U_I18N_API DateFormat * createDateInstance(EStyle style=kDefault, const Locale &aLocale=Locale::getDefault())
Creates a date formatter with the given formatting style for the given const locale.
double UDate
Date and Time data type.
Definition:utypes.h:218

If you are formatting multiple numbers, it is more efficient to get the format and use it multiple times so that the system doesn't have to fetch the information about the local language and country conventions multiple times.

DateFormat* df =DateFormat::createDateInstance();
UnicodeString myString;
UDate myDateArr[] = { 0.0, 100000000.0, 2000000000.0 };// test values
for (int32_t i = 0; i < 3; ++i) {
myString.remove();
cout << df->format( myDateArr[i], myString ) << endl;
}

To get specific fields of a date, you can useUFieldPosition to get specific fields.

DateFormat* dfmt =DateFormat::createDateInstance();
FieldPosition pos(DateFormat::YEAR_FIELD);
UnicodeString myString;
myString = dfmt->format( myDate, myString );
cout << myString << endl;
cout << pos.getBeginIndex() <<"," << pos. getEndIndex() << endl;

To format a date for a differentLocale, specify it in the call tocreateDateInstance().

DateFormat* df =
DateFormat::createDateInstance( DateFormat::SHORT,Locale::getFrance());
static U_COMMON_API const Locale & getFrance()
Useful constant for this country/region.

You can use aDateFormat to parse also.

UErrorCode status =U_ZERO_ERROR;
UDate myDate = df->parse(myString, status);
UErrorCode
Standard ICU4C error code type, a substitute for exceptions.
Definition:utypes.h:509
@ U_ZERO_ERROR
No error, no warning.
Definition:utypes.h:544

UsecreateDateInstance() to produce the normal date format for that country. There are other static factory methods available. UsecreateTimeInstance() to produce the normal time format for that country. UsecreateDateTimeInstance() to produce aDateFormat that formats both date and time. You can pass in different options to these factory methods to control the length of the result; from SHORT to MEDIUM to LONG to FULL. The exact result depends on the locale, but generally:

You can also set the time zone on the format if you wish. If you want even more control over the format or parsing, (or want to give your users more control), you can try casting theDateFormat you get from the factory methods to aSimpleDateFormat. This will work for the majority of countries; just remember to checkgetDynamicClassID() before carrying out the cast.

You can also use forms of the parse and format methods withParsePosition andFieldPosition to allow you to

User subclasses are not supported. While clients may write subclasses, such code will not necessarily work and will not be guaranteed to work stably from release to release.

Definition at line144 of filedatefmt.h.

Member Enumeration Documentation

◆ EField

enumicu::DateFormat::EField

Field selector forFieldPosition forDateFormat fields.

Obsolete:
ICU 3.4 use UDateFormatField instead, since this API will be removed in that release

Definition at line891 of filedatefmt.h.

◆ EStyle

enumicu::DateFormat::EStyle

Constants for various style patterns.

These reflect the order of items in the DateTimePatterns resource. There are 4 time patterns, 4 date patterns, the default date-time pattern, and 4 date-time patterns. Each block of 4 values in the resource occurs in the order full, long, medium, short.

Stable:
ICU 2.4
Enumerator
FULL 

These constants are provided for backwards compatibility only.

Please use the C++ style constants defined above.

Definition at line154 of filedatefmt.h.

Constructor & Destructor Documentation

◆ ~DateFormat()

virtualU_I18N_API icu::DateFormat::~DateFormat()
virtual

Destructor.

Stable:
ICU 2.0

◆ DateFormat()[1/2]

U_I18N_API icu::DateFormat::DateFormat()
protected

Default constructor.

Creates aDateFormat with noCalendar orNumberFormat associated with it. This constructor depends on the subclasses to fill in the calendar and numberFormat fields.

Stable:
ICU 2.0

◆ DateFormat()[2/2]

U_I18N_API icu::DateFormat::DateFormat(constDateFormat)
protected

Copy constructor.

Stable:
ICU 2.0

Member Function Documentation

◆ adoptCalendar()

virtualU_I18N_API void icu::DateFormat::adoptCalendar(CalendarcalendarToAdopt)
virtual

Set the calendar to be used by this date format.

Initially, the default calendar for the specified or default locale is used. The caller should not delete theCalendar object after it is adopted by this call. Adopting a new calendar will change to the default symbols.

Parameters
calendarToAdoptCalendar object to be adopted.
Stable:
ICU 2.0

Reimplemented inicu::SimpleDateFormat.

◆ adoptNumberFormat()

virtualU_I18N_API void icu::DateFormat::adoptNumberFormat(NumberFormatformatToAdopt)
virtual

Allows you to set the number formatter.

The caller should not delete theNumberFormat object after it is adopted by this call.

Parameters
formatToAdoptNumberFormat object to be adopted.
Stable:
ICU 2.0

Reimplemented inicu::SimpleDateFormat.

◆ adoptTimeZone()

virtualU_I18N_API void icu::DateFormat::adoptTimeZone(TimeZonezoneToAdopt)
virtual

Sets the time zone for the calendar of thisDateFormat object.

The caller no longer owns theTimeZone object and should not delete it after this call.

Parameters
zoneToAdopttheTimeZone to be adopted.
Stable:
ICU 2.0

◆ clone()

virtualU_I18N_APIDateFormat* icu::DateFormat::clone() const
overridepure virtual

Clones this object polymorphically.

The caller owns the result and should delete it when done.

Returns
clone, or nullptr if an error occurred
Stable:
ICU 2.0

Implementsicu::Format.

Implemented inicu::SimpleDateFormat.

◆ createDateInstance()

staticU_I18N_APIDateFormat* icu::DateFormat::createDateInstance(EStyle style =kDefault,
constLocaleaLocale =Locale::getDefault() 
)
static

Creates a date formatter with the given formatting style for the given const locale.

Parameters
styleThe given formatting style. For example, SHORT for "M/d/yy" in the US locale. As currently implemented, relative date formatting only affects a limited range of calendar days before or after the current date, based on the CLDR <field type="day">/<relative> data: For example, in English, "Yesterday", "Today", and "Tomorrow". Outside of this range, dates are formatted using the corresponding non-relative style.
aLocaleThe given locale.
Returns
A date formatter which the caller owns.
Stable:
ICU 2.0

◆ createDateTimeInstance()

staticU_I18N_APIDateFormat* icu::DateFormat::createDateTimeInstance(EStyle dateStyle =kDefault,
EStyle timeStyle =kDefault,
constLocaleaLocale =Locale::getDefault() 
)
static

Creates a date/time formatter with the given formatting styles for the given locale.

Parameters
dateStyleThe given formatting style for the date portion of the result. For example, SHORT for "M/d/yy" in the US locale. As currently implemented, relative date formatting only affects a limited range of calendar days before or after the current date, based on the CLDR <field type="day">/<relative> data: For example, in English, "Yesterday", "Today", and "Tomorrow". Outside of this range, dates are formatted using the corresponding non-relative style.
timeStyleThe given formatting style for the time portion of the result. For example, SHORT for "h:mm a" in the US locale. Relative time styles are not currently supported.
aLocaleThe given locale.
Returns
A date/time formatter which the caller owns.
Stable:
ICU 2.0

◆ createInstance()

staticU_I18N_APIDateFormat* icu::DateFormat::createInstance()
static

Create a default date/time formatter that uses the SHORT style for both the date and the time.

Returns
A date/time formatter which the caller owns.
Stable:
ICU 2.0

◆ createInstanceForSkeleton()[1/3]

staticU_I18N_APIDateFormat* icu::DateFormat::createInstanceForSkeleton(CalendarcalendarToAdopt,
constUnicodeStringskeleton,
constLocalelocale,
UErrorCodestatus 
)
static

Creates a date/time formatter for the given skeleton and locale.

Parameters
calendarToAdoptthe calendar returnedDateFormat is to use.
skeletonThe skeleton e.g "yMMMMd." Fields in the skeleton can be in any order, and this method uses the locale to map the skeleton to a pattern that includes locale specific separators with the fields in the appropriate order for that locale.
localeThe given locale.
statusAny error returned here.
Returns
A date/time formatter which the caller owns.
Stable:
ICU 55

◆ createInstanceForSkeleton()[2/3]

staticU_I18N_APIDateFormat* icu::DateFormat::createInstanceForSkeleton(constUnicodeStringskeleton,
constLocalelocale,
UErrorCodestatus 
)
static

Creates a date/time formatter for the given skeleton and locale.

Parameters
skeletonThe skeleton e.g "yMMMMd." Fields in the skeleton can be in any order, and this method uses the locale to map the skeleton to a pattern that includes locale specific separators with the fields in the appropriate order for that locale.
localeThe given locale.
statusAny error returned here.
Returns
A date/time formatter which the caller owns.
Stable:
ICU 55

◆ createInstanceForSkeleton()[3/3]

staticU_I18N_APIDateFormat* icu::DateFormat::createInstanceForSkeleton(constUnicodeStringskeleton,
UErrorCodestatus 
)
static

Creates a date/time formatter for the given skeleton and default locale.

Parameters
skeletonThe skeleton e.g "yMMMMd." Fields in the skeleton can be in any order, and this method uses the locale to map the skeleton to a pattern that includes locale specific separators with the fields in the appropriate order for that locale.
statusAny error returned here.
Returns
A date/time formatter which the caller owns.
Stable:
ICU 55

◆ createTimeInstance()

staticU_I18N_APIDateFormat* icu::DateFormat::createTimeInstance(EStyle style =kDefault,
constLocaleaLocale =Locale::getDefault() 
)
static

Creates a time formatter with the given formatting style for the given locale.

Parameters
styleThe given formatting style. For example, SHORT for "h:mm a" in the US locale. Relative time styles are not currently supported.
aLocaleThe given locale.
Returns
A time formatter which the caller owns.
Stable:
ICU 2.0

◆ format()[1/10]

virtualU_I18N_APIUnicodeString& icu::DateFormat::format(Calendarcal,
UnicodeStringappendTo,
FieldPositionfieldPosition 
) const
pure virtual

Formats a date into a date/time string.

This is an abstract method which concrete subclasses must implement.

On input, theFieldPosition parameter may have its "field" member filled with an enum value specifying a field. On output, theFieldPosition will be filled in with the text offsets for that field.

For example, given a time text "1996.07.10 AD at 15:08:56 PDT", if the given fieldPosition.field is UDAT_YEAR_FIELD, the offsets fieldPosition.beginIndex and statfieldPositionus.getEndIndex will be set to 0 and 4, respectively.

Notice that if the same time field appears more than once in a pattern, the status will be set for the first occurrence of that time field. For instance, formatting a UDate to the time string "1 PM PDT (Pacific Daylight Time)" using the pattern "h a z (zzzz)" and the alignment field DateFormat::TIMEZONE_FIELD, the offsets fieldPosition.beginIndex and fieldPosition.getEndIndex will be set to 5 and 8, respectively, for the first occurrence of the timezone pattern character 'z'.

Parameters
calCalendar set to the date and time to be formatted into a date/time string. When the calendar type is different from the internal calendar held by thisDateFormat instance, the date and the time zone will be inherited from the input calendar, but other calendar field values will be calculated by the internal calendar.
appendToOutput parameter to receive result. Result is appended to existing contents.
fieldPositionOn input: an alignment field, if desired (see examples above) On output: the offsets of the alignment field (see examples above)
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.1

Implemented inicu::SimpleDateFormat.

◆ format()[2/10]

virtualU_I18N_APIUnicodeString& icu::DateFormat::format(Calendarcal,
UnicodeStringappendTo,
FieldPositionIteratorposIter,
UErrorCodestatus 
) const
virtual

Formats a date into a date/time string.

Subclasses should implement this method.

Parameters
calCalendar set to the date and time to be formatted into a date/time string. When the calendar type is different from the internal calendar held by thisDateFormat instance, the date and the time zone will be inherited from the input calendar, but other calendar field values will be calculated by the internal calendar.
appendToOutput parameter to receive result. Result is appended to existing contents.
posIterOn return, can be used to iterate over positions of fields generated by this format call. Field values are defined in UDateFormatField. Can be nullptr.
statuserror status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 4.4

Reimplemented inicu::SimpleDateFormat.

◆ format()[3/10]

virtualU_I18N_APIUnicodeString& icu::DateFormat::format(constFormattableobj,
UnicodeStringappendTo,
FieldPositionpos,
UErrorCodestatus 
) const
overridevirtual

Format an object to produce a string.

This method handlesFormattable objects with a UDate type. If a theFormattable object type is not a Date, then it returns a failing UErrorCode.

Parameters
objThe object to format. Must be a Date.
appendToOutput parameter to receive result. Result is appended to existing contents.
posOn input: an alignment field, if desired. On output: the offsets of the alignment field.
statusOutput param filled with success/failure status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.0

Implementsicu::Format.

◆ format()[4/10]

virtualU_I18N_APIUnicodeString& icu::Format::format

Format an object to produce a string.

This is a pure virtual method which subclasses must implement. This method allows polymorphic formatting ofFormattable objects. If a subclass ofFormat receives aFormattable object type it doesn't handle (e.g., if a numericFormattable is passed to aDateFormat object) then it returns a failing UErrorCode.

Parameters
objThe object to format.
appendToOutput parameter to receive result. Result is appended to existing contents.
posOn input: an alignment field, if desired. On output: the offsets of the alignment field.
statusOutput param filled with success/failure status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.0

◆ format()[5/10]

virtualU_I18N_APIUnicodeString& icu::Format::format

Format an object to produce a string.

Subclasses should override this method. This method allows polymorphic formatting ofFormattable objects. If a subclass ofFormat receives aFormattable object type it doesn't handle (e.g., if a numericFormattable is passed to aDateFormat object) then it returns a failing UErrorCode.

Parameters
objThe object to format.
appendToOutput parameter to receive result. Result is appended to existing contents.
posIterOn return, can be used to iterate over positions of fields generated by this format call.
statusOutput param filled with success/failure status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 4.4

◆ format()[6/10]

virtualU_I18N_APIUnicodeString& icu::DateFormat::format(constFormattableobj,
UnicodeStringappendTo,
FieldPositionIteratorposIter,
UErrorCodestatus 
) const
overridevirtual

Format an object to produce a string.

This method handlesFormattable objects with a UDate type. If a theFormattable object type is not a Date, then it returns a failing UErrorCode.

Parameters
objThe object to format. Must be a Date.
appendToOutput parameter to receive result. Result is appended to existing contents.
posIterOn return, can be used to iterate over positions of fields generated by this format call. Field values are defined in UDateFormatField. Can be nullptr.
statusOutput param filled with success/failure status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 4.4

Reimplemented fromicu::Format.

◆ format()[7/10]

U_I18N_APIUnicodeString& icu::Format::format

Formats an object to produce a string.

Parameters
objThe object to format.
appendToOutput parameter to receive result. Result is appended to existing contents.
statusOutput parameter filled in with success or failure status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.0

◆ format()[8/10]

U_I18N_APIUnicodeString& icu::DateFormat::format(UDate date,
UnicodeStringappendTo 
) const

Formats a UDate into a date/time string.

If there is a problem, you won't know, using this method. Use the overloadedformat() method which takes aFieldPosition& to detect formatting problems.

Parameters
dateThe UDate value to be formatted into a string.
appendToOutput parameter to receive result. Result is appended to existing contents.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.0

◆ format()[9/10]

U_I18N_APIUnicodeString& icu::DateFormat::format(UDate date,
UnicodeStringappendTo,
FieldPositionfieldPosition 
) const

Formats a UDate into a date/time string.

On input, theFieldPosition parameter may have its "field" member filled with an enum value specifying a field. On output, theFieldPosition will be filled in with the text offsets for that field.

For example, given a time text "1996.07.10 AD at 15:08:56 PDT", if the given fieldPosition.field is UDAT_YEAR_FIELD, the offsets fieldPosition.beginIndex and statfieldPositionus.getEndIndex will be set to 0 and 4, respectively.

Notice that if the same time field appears more than once in a pattern, the status will be set for the first occurrence of that time field. For instance, formatting a UDate to the time string "1 PM PDT (Pacific Daylight Time)" using the pattern "h a z (zzzz)" and the alignment field DateFormat::TIMEZONE_FIELD, the offsets fieldPosition.beginIndex and fieldPosition.getEndIndex will be set to 5 and 8, respectively, for the first occurrence of the timezone pattern character 'z'.

Parameters
dateUDate to be formatted into a date/time string.
appendToOutput parameter to receive result. Result is appended to existing contents.
fieldPositionOn input: an alignment field, if desired (see examples above) On output: the offsets of the alignment field (see examples above)
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 2.0

◆ format()[10/10]

U_I18N_APIUnicodeString& icu::DateFormat::format(UDate date,
UnicodeStringappendTo,
FieldPositionIteratorposIter,
UErrorCodestatus 
) const

Formats a UDate into a date/time string.

Parameters
dateUDate to be formatted into a date/time string.
appendToOutput parameter to receive result. Result is appended to existing contents.
posIterOn return, can be used to iterate over positions of fields generated by this format call. Field values are defined in UDateFormatField. Can be nullptr.
statuserror status.
Returns
Reference to 'appendTo' parameter.
Stable:
ICU 4.4

◆ getAvailableLocales()

staticU_I18N_API constLocale* icu::DateFormat::getAvailableLocales(int32_t & count)
static

Gets the set of locales for which DateFormats are installed.

Parameters
countFilled in with the number of locales in the list that is returned.
Returns
the set of locales for which DateFormats are installed. The caller does NOT own this list and must not delete it.
Stable:
ICU 2.0

◆ getBestPattern()

staticU_I18N_APIUnicodeString icu::DateFormat::getBestPattern(constLocalelocale,
constUnicodeStringskeleton,
UErrorCodestatus 
)
static

Returns the best pattern given a skeleton and locale.

Parameters
localethe locale
skeletonthe skeleton
statusICU error returned here
Returns
the best pattern.
Internal:
Do not use. This API is for internal use only. For ICU use only.

◆ getBooleanAttribute()

virtualU_I18N_APIUBool icu::DateFormat::getBooleanAttribute(UDateFormatBooleanAttribute attr,
UErrorCodestatus 
) const
virtual

Returns a boolean from thisDateFormat May return U_UNSUPPORTED_ERROR if this instance does not support the specified attribute.

Parameters
attrthe attribute to set
statusthe error type
Returns
the attribute value. Undefined if there is an error.
Stable:
ICU 53

◆ getCalendar()

virtualU_I18N_API constCalendar* icu::DateFormat::getCalendar() const
virtual

Gets the calendar associated with this date/time formatter.

The calendar is owned by the formatter and must not be modified. Also, the calendar does not reflect the results of a parse operation. To parse to a calendar, useparse(const UnicodeString&, Calendar& cal, ParsePosition&)

Returns
the calendar associated with this date/time formatter.
Stable:
ICU 2.0

◆ getContext()

virtualU_I18N_APIUDisplayContext icu::DateFormat::getContext(UDisplayContextType type,
UErrorCodestatus 
) const
virtual

Get the formatter's UDisplayContext value for the specified UDisplayContextType, such as UDISPCTX_TYPE_CAPITALIZATION.

Parameters
typeThe UDisplayContextType whose value to return
statusInput/output status. If at entry this indicates a failure status, the function will do nothing; otherwise this will be updated with any new status from the function.
Returns
The UDisplayContextValue for the specified type.
Stable:
ICU 53

◆ getNumberFormat()

virtualU_I18N_API constNumberFormat* icu::DateFormat::getNumberFormat() const
virtual

Gets the number formatter which this date/time formatter uses to format and parse the numeric portions of the pattern.

Returns
the number formatter which this date/time formatter uses.
Stable:
ICU 2.0

◆ getTimeZone()

virtualU_I18N_API constTimeZone& icu::DateFormat::getTimeZone() const
virtual

Returns a reference to theTimeZone used by thisDateFormat's calendar.

Returns
the time zone associated with the calendar ofDateFormat.
Stable:
ICU 2.0

◆ isCalendarLenient()

virtualU_I18N_APIUBool icu::DateFormat::isCalendarLenient() const
virtual

Returns whether date/time parsing in the encapsulatedCalendar object processing is lenient.

Stable:
ICU 53

◆ isLenient()

virtualU_I18N_APIUBool icu::DateFormat::isLenient() const
virtual

Returns whether both date/time parsing in the encapsulatedCalendar object andDateFormat whitespace & numeric processing is lenient.

Stable:
ICU 2.0

◆ operator=()

U_I18N_APIDateFormat& icu::DateFormat::operator=(constDateFormat)
protected

Default assignment operator.

Stable:
ICU 2.0

◆ operator==()

virtualU_I18N_API bool icu::DateFormat::operator==(constFormat) const
overridevirtual

Equality operator.

Returns true if the two formats have the same behavior.

Stable:
ICU 2.0

Implementsicu::Format.

Reimplemented inicu::SimpleDateFormat.

◆ parse()[1/3]

virtualU_I18N_API void icu::DateFormat::parse(constUnicodeStringtext,
Calendarcal,
ParsePositionpos 
) const
pure virtual

Parse a date/time string beginning at the given parse position.

For example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date that is equivalent to Date(837039928046).

By default, parsing is lenient: If the input is not in the form used by this object's format method but can still be parsed as a date, then the parse succeeds. Clients may insist on strict adherence to the format by calling setLenient(false).

See also
DateFormat::setLenient(boolean)
Parameters
textThe date/time string to be parsed.
calACalendar set on input to the date and time to be used for missing values in the date/time string being parsed, and set on output to the parsed date/time. When the calendar type is different from the internal calendar held by thisDateFormat instance, the internal calendar will be cloned to a work calendar set to the same milliseconds and time zone as the cal parameter, field values will be parsed based on the work calendar, then the result (milliseconds and time zone) will be set in this calendar.
posOn input, the position at which to start parsing; on output, the position at which parsing terminated, or the start position if the parse failed.
Stable:
ICU 2.1

Implemented inicu::SimpleDateFormat.

◆ parse()[2/3]

U_I18N_APIUDate icu::DateFormat::parse(constUnicodeStringtext,
ParsePositionpos 
) const

Parse a date/time string beginning at the given parse position.

For example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date that is equivalent to Date(837039928046).

By default, parsing is lenient: If the input is not in the form used by this object's format method but can still be parsed as a date, then the parse succeeds. Clients may insist on strict adherence to the format by calling setLenient(false).

See also
DateFormat::setLenient(boolean)

Note that the normal date formats associated with some calendars - such as the Chinese lunar calendar - do not specify enough fields to enable dates to be parsed unambiguously. In the case of the Chinese lunar calendar, while the year within the current 60-year cycle is specified, the number of such cycles since the start date of the calendar (in the ERA field of theCalendar object) is not normally part of the format, and parsing may assume the wrong era. For cases such as this it is recommended that clients parse using the method parse(const UnicodeString&, Calendar& cal, ParsePosition&) with theCalendar passed in set to the current date, or to a date within the era/cycle that should be assumed if absent in the format.

Parameters
textThe date/time string to be parsed into a UDate value.
posOn input, the position at which to start parsing; on output, the position at which parsing terminated, or the start position if the parse failed.
Returns
A valid UDate if the input could be parsed.
Stable:
ICU 2.0

◆ parse()[3/3]

virtualU_I18N_APIUDate icu::DateFormat::parse(constUnicodeStringtext,
UErrorCodestatus 
) const
virtual

Parse a date/time string.

For example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a UDate that is equivalent to Date(837039928046). Parsing begins at the beginning of the string and proceeds as far as possible. Assuming no parse errors were encountered, this function doesn't return any information about how much of the string was consumed by the parsing. If you need that information, use the version ofparse() that takes aParsePosition.

By default, parsing is lenient: If the input is not in the form used by this object's format method but can still be parsed as a date, then the parse succeeds. Clients may insist on strict adherence to the format by calling setLenient(false).

See also
DateFormat::setLenient(boolean)

Note that the normal date formats associated with some calendars - such as the Chinese lunar calendar - do not specify enough fields to enable dates to be parsed unambiguously. In the case of the Chinese lunar calendar, while the year within the current 60-year cycle is specified, the number of such cycles since the start date of the calendar (in the ERA field of theCalendar object) is not normally part of the format, and parsing may assume the wrong era. For cases such as this it is recommended that clients parse using the method parse(const UnicodeString&, Calendar& cal, ParsePosition&) with theCalendar passed in set to the current date, or to a date within the era/cycle that should be assumed if absent in the format.

Parameters
textThe date/time string to be parsed into a UDate value.
statusOutput param to be set to success/failure code. If 'text' cannot be parsed, it will be set to a failure code.
Returns
The parsed UDate value, if successful.
Stable:
ICU 2.0

◆ parseObject()

virtualU_I18N_API void icu::DateFormat::parseObject(constUnicodeStringsource,
Formattableresult,
ParsePositionparse_pos 
) const
overridevirtual

Parse a string to produce an object.

This methods handles parsing of date/time strings intoFormattable objects with UDate types.

Before calling, set parse_pos.index to the offset you want to start parsing at in the source. After calling, parse_pos.index is the end of the text you parsed. If error occurs, index is unchanged.

When parsing, leading whitespace is discarded (with a successful parse), while trailing whitespace is left as is.

SeeFormat::parseObject() for more.

Parameters
sourceThe string to be parsed into an object.
resultFormattable to be set to the parse result. If parse fails, return contents are undefined.
parse_posThe position to start parsing at. Upon return this param is set to the position after the last character successfully parsed. If the source is not parsed successfully, this param will remain unchanged.
Stable:
ICU 2.0

Implementsicu::Format.

◆ setBooleanAttribute()

virtualU_I18N_APIDateFormat& icu::DateFormat::setBooleanAttribute(UDateFormatBooleanAttribute attr,
UBool newvalue,
UErrorCodestatus 
)
virtual

Sets an boolean attribute on thisDateFormat.

May return U_UNSUPPORTED_ERROR if this instance does not support the specified attribute.

Parameters
attrthe attribute to set
newvaluenew value
statusthe error type
Returns
*this - for chaining (example: format.setAttribute(...).setAttribute(...) )
Stable:
ICU 53

◆ setCalendar()

virtualU_I18N_API void icu::DateFormat::setCalendar(constCalendarnewCalendar)
virtual

Set the calendar to be used by this date format.

Initially, the default calendar for the specified or default locale is used.

Parameters
newCalendarCalendar object to be set.
Stable:
ICU 2.0

◆ setCalendarLenient()

virtualU_I18N_API void icu::DateFormat::setCalendarLenient(UBool lenient)
virtual

Specifies whether encapsulatedCalendar date/time parsing is to be lenient.

With lenient parsing, the parser may use heuristics to interpret inputs that do not precisely match this object's format. Without lenient parsing, inputs must match this object's format more closely.

Parameters
lenientwhen true, parsing is lenient
See also
com.ibm.icu.util.Calendar::setLenient
Stable:
ICU 53

◆ setContext()

virtualU_I18N_API void icu::DateFormat::setContext(UDisplayContext value,
UErrorCodestatus 
)
virtual

Set a particular UDisplayContext value in the formatter, such as UDISPCTX_CAPITALIZATION_FOR_STANDALONE.

Parameters
valueThe UDisplayContext value to set.
statusInput/output status. If at entry this indicates a failure status, the function will do nothing; otherwise this will be updated with any new status from the function.
Stable:
ICU 53

Reimplemented inicu::SimpleDateFormat.

◆ setLenient()

virtualU_I18N_API void icu::DateFormat::setLenient(UBool lenient)
virtual

Specifies whether date/time parsing is to be lenient.

With lenient parsing, the parser may use heuristics to interpret inputs that do not precisely match this object's format. Without lenient parsing, inputs must match this object's format more closely.

Note: ICU 53 introduced finer grained control of leniency (and added new control points) making the preferred method a combination ofsetCalendarLenient() &setBooleanAttribute() calls. This method supports prior functionality but may not support all future leniency control & behavior ofDateFormat. For control of pre 53 leniency,
Calendar andDateFormat whitespace & numeric tolerance, this method is safe to use. However, mixing leniency control via this method and modification of the newer attributes viasetBooleanAttribute() may produce undesirable results.

Parameters
lenientTrue specifies date/time interpretation to be lenient.
See also
Calendar::setLenient
Stable:
ICU 2.0

◆ setNumberFormat()

virtualU_I18N_API void icu::DateFormat::setNumberFormat(constNumberFormatnewNumberFormat)
virtual

Allows you to set the number formatter.

Parameters
newNumberFormatNumberFormat object to be set.
Stable:
ICU 2.0

◆ setTimeZone()

virtualU_I18N_API void icu::DateFormat::setTimeZone(constTimeZonezone)
virtual

Sets the time zone for the calendar of thisDateFormat object.

Parameters
zonethe new time zone.
Stable:
ICU 2.0

Field Documentation

◆ fCalendar

Calendar* icu::DateFormat::fCalendar
protected

The calendar thatDateFormat uses to produce the time field values needed to implement date/time formatting.

Subclasses should generally initialize this to the default calendar for the locale associated with thisDateFormat.

Stable:
ICU 2.4

Definition at line851 of filedatefmt.h.

◆ fNumberFormat

NumberFormat* icu::DateFormat::fNumberFormat
protected

The number formatter thatDateFormat uses to format numbers in dates and times.

Subclasses should generally initialize this to the default number format for the locale associated with thisDateFormat.

Stable:
ICU 2.4

Definition at line859 of filedatefmt.h.


The documentation for this class was generated from the following file:

Generated by doxygen 1.9.1
[8]ページ先頭

©2009-2025 Movatter.jp