annotate babel/dates.py @ 8:9132c9218745

Pull in some supplemental data from the CLDR, for things like the first day of the week.
author cmlenz
date Wed, 30 May 2007 17:39:43 +0000
parents f71ca60f2a4a
children a2c54ef107c2
rev   line source
1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
1 # -*- coding: utf-8 -*-
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
2 #
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
3 # Copyright (C) 2007 Edgewall Software
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
4 # All rights reserved.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
5 #
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
6 # This software is licensed as described in the file COPYING, which
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
7 # you should have received as part of this distribution. The terms
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
8 # are also available at http://babel.edgewall.org/wiki/License.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
9 #
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
10 # This software consists of voluntary contributions made by many
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
11 # individuals. For the exact contribution history, see the revision
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
12 # history and logs, available at http://babel.edgewall.org/log/.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
13
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
14 """Locale dependent formatting and parsing of dates and times.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
15
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
16 The default locale for the functions in this module is determined by the
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
17 following environment variables, in that order:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
18
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
19 * ``LC_TIME``,
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
20 * ``LC_ALL``, and
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
21 * ``LANG``
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
22 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
23
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
24 from datetime import date, datetime, time
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
25
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
26 from babel.core import Locale
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
27 from babel.util import default_locale
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
28
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
29 __all__ = ['format_date', 'format_datetime', 'format_time', 'parse_date',
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
30 'parse_datetime', 'parse_time']
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
31 __docformat__ = 'restructuredtext en'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
32
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
33 LC_TIME = default_locale('LC_TIME')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
34
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
35 def get_period_names(locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
36 """Return the names for day periods (AM/PM) used by the locale.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
37
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
38 >>> get_period_names(locale='en_US')['am']
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
39 u'AM'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
40
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
41 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
42 :return: the dictionary of period names
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
43 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
44 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
45 return Locale.parse(locale).periods
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
46
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
47 def get_day_names(width='wide', context='format', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
48 """Return the day names used by the locale for the specified format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
49
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
50 >>> get_day_names('wide', locale='en_US')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
51 u'Monday'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
52 >>> get_day_names('abbreviated', locale='es')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
53 u'lun'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
54 >>> get_day_names('narrow', context='stand-alone', locale='de_DE')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
55 u'M'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
56
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
57 :param width: the width to use, one of "wide", "abbreviated", or "narrow"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
58 :param context: the context, either "format" or "stand-alone"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
59 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
60 :return: the dictionary of day names
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
61 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
62 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
63 return Locale.parse(locale).days[context][width]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
64
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
65 def get_month_names(width='wide', context='format', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
66 """Return the month names used by the locale for the specified format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
67
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
68 >>> get_month_names('wide', locale='en_US')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
69 u'January'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
70 >>> get_month_names('abbreviated', locale='es')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
71 u'ene'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
72 >>> get_month_names('narrow', context='stand-alone', locale='de_DE')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
73 u'J'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
74
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
75 :param width: the width to use, one of "wide", "abbreviated", or "narrow"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
76 :param context: the context, either "format" or "stand-alone"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
77 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
78 :return: the dictionary of month names
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
79 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
80 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
81 return Locale.parse(locale).months[context][width]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
82
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
83 def get_quarter_names(width='wide', context='format', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
84 """Return the quarter names used by the locale for the specified format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
85
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
86 >>> get_quarter_names('wide', locale='en_US')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
87 u'1st quarter'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
88 >>> get_quarter_names('abbreviated', locale='de_DE')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
89 u'Q1'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
90
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
91 :param width: the width to use, one of "wide", "abbreviated", or "narrow"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
92 :param context: the context, either "format" or "stand-alone"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
93 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
94 :return: the dictionary of quarter names
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
95 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
96 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
97 return Locale.parse(locale).quarters[context][width]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
98
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
99 def get_era_names(width='wide', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
100 """Return the era names used by the locale for the specified format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
101
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
102 >>> get_era_names('wide', locale='en_US')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
103 u'Anno Domini'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
104 >>> get_era_names('abbreviated', locale='de_DE')[1]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
105 u'n. Chr.'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
106
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
107 :param width: the width to use, either "wide" or "abbreviated"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
108 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
109 :return: the dictionary of era names
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
110 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
111 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
112 return Locale.parse(locale).eras[width]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
113
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
114 def get_date_format(format='medium', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
115 """Return the date formatting patterns used by the locale for the specified
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
116 format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
117
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
118 >>> get_date_format(locale='en_US')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
119 <DateTimeFormatPattern u'MMM d, yyyy'>
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
120 >>> get_date_format('full', locale='de_DE')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
121 <DateTimeFormatPattern u'EEEE, d. MMMM yyyy'>
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
122
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
123 :param format: the format to use, one of "full", "long", "medium", or
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
124 "short"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
125 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
126 :return: the date format pattern
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
127 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
128 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
129 return Locale.parse(locale).date_formats[format]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
130
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
131 def get_time_format(format='medium', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
132 """Return the time formatting patterns used by the locale for the specified
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
133 format.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
134
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
135 >>> get_time_format(locale='en_US')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
136 <DateTimeFormatPattern u'h:mm:ss a'>
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
137 >>> get_time_format('full', locale='de_DE')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
138 <DateTimeFormatPattern u"H:mm' Uhr 'z">
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
139
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
140 :param format: the format to use, one of "full", "long", "medium", or
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
141 "short"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
142 :param locale: the `Locale` object, or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
143 :return: the time format pattern
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
144 :rtype: `dict`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
145 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
146 return Locale.parse(locale).time_formats[format]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
147
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
148 def format_date(date, format='medium', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
149 """Returns a date formatted according to the given pattern.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
150
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
151 >>> d = date(2007, 04, 01)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
152 >>> format_date(d, locale='en_US')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
153 u'Apr 1, 2007'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
154 >>> format_date(d, format='full', locale='de_DE')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
155 u'Sonntag, 1. April 2007'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
156
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
157 :param date: the ``date`` object
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
158 :param format: one of "full", "long", "medium", or "short"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
159 :param locale: a `Locale` object or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
160 :rtype: `unicode`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
161 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
162 locale = Locale.parse(locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
163 if format in ('full', 'long', 'medium', 'short'):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
164 format = get_date_format(format, locale=locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
165 pattern = parse_pattern(format)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
166 return parse_pattern(format).apply(date, locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
167
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
168 def format_datetime(datetime, format='medium', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
169 """Returns a date formatted according to the given pattern.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
170
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
171 :param datetime: the ``date`` object
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
172 :param format: one of "full", "long", "medium", or "short"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
173 :param locale: a `Locale` object or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
174 :rtype: `unicode`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
175 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
176 raise NotImplementedError
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
177
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
178 def format_time(time, format='medium', locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
179 """Returns a time formatted according to the given pattern.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
180
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
181 >>> t = time(15, 30)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
182 >>> format_time(t, locale='en_US')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
183 u'3:30:00 PM'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
184 >>> format_time(t, format='short', locale='de_DE')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
185 u'15:30'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
186
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
187 :param time: the ``time`` object
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
188 :param format: one of "full", "long", "medium", or "short"
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
189 :param locale: a `Locale` object or a locale string
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
190 :rtype: `unicode`
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
191 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
192 locale = Locale.parse(locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
193 if format in ('full', 'long', 'medium', 'short'):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
194 format = get_time_format(format, locale=locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
195 return parse_pattern(format).apply(time, locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
196
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
197 def parse_date(string, locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
198 raise NotImplementedError
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
199
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
200 def parse_datetime(string, locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
201 raise NotImplementedError
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
202
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
203 def parse_time(string, locale=LC_TIME):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
204 raise NotImplementedError
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
205
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
206
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
207 class DateTimeFormatPattern(object):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
208
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
209 def __init__(self, pattern, format):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
210 self.pattern = pattern
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
211 self.format = format
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
212
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
213 def __repr__(self):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
214 return '<%s %r>' % (type(self).__name__, self.pattern)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
215
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
216 def __unicode__(self):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
217 return self.pattern
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
218
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
219 def __mod__(self, other):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
220 assert type(other) is DateTimeFormat
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
221 return self.format % other
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
222
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
223 def apply(self, datetime, locale):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
224 return self % DateTimeFormat(datetime, locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
225
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
226
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
227 class DateTimeFormat(object):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
228
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
229 def __init__(self, value, locale):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
230 assert isinstance(value, (date, datetime, time))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
231 self.value = value
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
232 self.locale = Locale.parse(locale)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
233
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
234 def __getitem__(self, name):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
235 # TODO: a number of fields missing here
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
236 if name[0] == 'G':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
237 return self.format_era(len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
238 elif name[0] == 'y':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
239 return self.format_year(self.value.year, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
240 elif name[0] == 'Y':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
241 return self.format_year(self.value.isocalendar()[0], len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
242 elif name[0] == 'Q':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
243 return self.format_quarter(len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
244 elif name[0] == 'q':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
245 return self.format_quarter(len(name), context='stand-alone')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
246 elif name[0] == 'M':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
247 return self.format_month(len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
248 elif name[0] == 'L':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
249 return self.format_month(len(name), context='stand-alone')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
250 elif name[0] == 'd':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
251 return self.format(self.value.day, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
252 elif name[0] == 'E':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
253 return self.format_weekday(len(name))
8
9132c9218745 Pull in some supplemental data from the CLDR, for things like the first day of the week.
cmlenz
parents: 1
diff changeset
254 elif name[0] == 'e':
9132c9218745 Pull in some supplemental data from the CLDR, for things like the first day of the week.
cmlenz
parents: 1
diff changeset
255 return self.format_weekday(len(name), add_firstday=True)
1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
256 elif name[0] == 'c':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
257 return self.format_weekday(len(name), context='stand-alone')
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
258 elif name[0] == 'a':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
259 return self.format_period()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
260 elif name[0] == 'h':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
261 return self.format(self.value.hour % 12, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
262 elif name[0] == 'H':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
263 return self.format(self.value.hour, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
264 elif name[0] == 'm':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
265 return self.format(self.value.minute, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
266 elif name[0] == 's':
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
267 return self.format(self.value.second, len(name))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
268 else:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
269 raise KeyError('Unsupported date/time field %r' % name[0])
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
270
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
271 def format_era(self, num):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
272 width = {3: 'abbreviated', 4: 'wide', 5: 'narrow'}[max(3, num)]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
273 era = int(self.value.year >= 0)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
274 return get_era_names(width, self.locale)[era]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
275
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
276 def format_year(self, value, num):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
277 year = self.format(value, num)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
278 if num == 2:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
279 year = year[-2:]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
280 return year
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
281
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
282 def format_month(self, num, context='format'):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
283 if num <= 2:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
284 return ('%%0%dd' % num) % self.value.month
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
285 width = {3: 'abbreviated', 4: 'wide', 5: 'narrow'}[num]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
286 return get_month_names(width, context, self.locale)[self.value.month]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
287
8
9132c9218745 Pull in some supplemental data from the CLDR, for things like the first day of the week.
cmlenz
parents: 1
diff changeset
288 def format_weekday(self, num, add_firstday=False, context='format'):
1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
289 width = {3: 'abbreviated', 4: 'wide', 5: 'narrow'}[max(3, num)]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
290 weekday = self.value.weekday() + 1
8
9132c9218745 Pull in some supplemental data from the CLDR, for things like the first day of the week.
cmlenz
parents: 1
diff changeset
291 if add_firstday:
9132c9218745 Pull in some supplemental data from the CLDR, for things like the first day of the week.
cmlenz
parents: 1
diff changeset
292 weekday += self.locale.first_week_day
1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
293 return get_day_names(width, context, self.locale)[weekday]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
294
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
295 def format_period(self):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
296 period = {0: 'am', 1: 'pm'}[int(self.value.hour > 12)]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
297 return get_period_names(locale=self.locale)[period]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
298
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
299 def format(self, value, length):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
300 return ('%%0%dd' % length) % value
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
301
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
302
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
303 PATTERN_CHARS = {
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
304 'G': 5, # era
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
305 'y': None, 'Y': None, 'u': None, # year
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
306 'Q': 4, 'q': 4, # quarter
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
307 'M': 5, 'L': 5, # month
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
308 'w': 2, 'W': 1, # week
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
309 'd': 2, 'D': 3, 'F': 1, 'g': None, # day
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
310 'E': 5, 'e': 5, 'c': 5, # week day
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
311 'a': 1, # period
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
312 'h': 2, 'H': 2, 'K': 2, 'k': 2, # hour
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
313 'm': 2, # minute
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
314 's': 2, 'S': None, 'A': None, # second
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
315 'z': 4, 'Z': 4, 'v': 4 # zone
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
316 }
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
317
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
318 def parse_pattern(pattern):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
319 """Parse date, time, and datetime format patterns.
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
320
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
321 >>> parse_pattern("MMMMd").format
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
322 u'%(MMMM)s%(d)s'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
323 >>> parse_pattern("MMM d, yyyy").format
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
324 u'%(MMM)s %(d)s, %(yyyy)s'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
325 >>> parse_pattern("H:mm' Uhr 'z").format
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
326 u'%(H)s:%(mm)s Uhr %(z)s'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
327
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
328 :param pattern: the formatting pattern to parse
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
329 """
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
330 if type(pattern) is DateTimeFormatPattern:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
331 return pattern
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
332
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
333 result = []
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
334 quotebuf = None
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
335 charbuf = []
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
336 fieldchar = ['']
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
337 fieldnum = [0]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
338
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
339 def append_chars():
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
340 result.append(''.join(charbuf).replace('%', '%%'))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
341 del charbuf[:]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
342
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
343 def append_field():
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
344 limit = PATTERN_CHARS[fieldchar[0]]
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
345 if limit is not None and fieldnum[0] > limit:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
346 raise ValueError('Invalid length for field: %r'
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
347 % (fieldchar[0] * fieldnum[0]))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
348 result.append('%%(%s)s' % (fieldchar[0] * fieldnum[0]))
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
349 fieldchar[0] = ''
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
350 fieldnum[0] = 0
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
351
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
352 for idx, char in enumerate(pattern):
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
353 if quotebuf is None:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
354 if char == "'": # quote started
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
355 if fieldchar[0]:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
356 append_field()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
357 elif charbuf:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
358 append_chars()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
359 quotebuf = []
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
360 elif char in PATTERN_CHARS:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
361 if charbuf:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
362 append_chars()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
363 if char == fieldchar[0]:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
364 fieldnum[0] += 1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
365 else:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
366 if fieldchar[0]:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
367 append_field()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
368 fieldchar[0] = char
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
369 fieldnum[0] = 1
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
370 else:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
371 if fieldchar[0]:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
372 append_field()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
373 charbuf.append(char)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
374
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
375 elif quotebuf is not None:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
376 if char == "'": # quote ended
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
377 charbuf.extend(quotebuf)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
378 quotebuf = None
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
379 else: # inside quote
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
380 quotebuf.append(char)
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
381
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
382 if fieldchar[0]:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
383 append_field()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
384 elif charbuf:
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
385 append_chars()
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
386
f71ca60f2a4a Import of initial code base.
cmlenz
parents:
diff changeset
387 return DateTimeFormatPattern(pattern, u''.join(result))
Copyright (C) 2012-2017 Edgewall Software