Почему вы даже беспокоитесь?
Чтобы использовать этот TFunctions.GetInterface, вам нужно:
Если у вас есть это, вы можете просто вызвать Supports () напрямую:
intf: = TFunctions.GetInterface & lt; IMyInterface & gt; (myObject);
является точно , эквивалентным:
Поддерживает (IMyInterface, myObject, intf);
Использование дженериков здесь пустая трата времени и усилий и действительно задает вопрос «Зачем это делать?».
Это просто усложняет чтение (как так как это часто случается с дженериками) и является более громоздким в использовании.
Supports () возвращает удобное логическое значение для указания успеха / отказа, которое вы должны тестировать отдельно с помощью вашей обертки:
intf: = TFunctions.GetInterface & lt; IMyInterface & gt; (myObject); Если Assigned (intf), то // ...
против:
, если поддерживает (IMyInterface, myObject, intf), то // Мы можем использовать intf
При создании оберток вокруг функциональности обычно бывает, что результатом является улучшение читабельности или удобства использования.
imho это не работает по обоим пунктам, и вы должны просто придерживаться с самой поддержкой функции Supports ().
Пример, данный Роб, замечательный, но не является потокобезопасным. Вот версия, которая работает с потоками:
import locale
import threading
from datetime import datetime
from contextlib import contextmanager
LOCALE_LOCK = threading.Lock()
@contextmanager
def setlocale(name):
with LOCALE_LOCK:
saved = locale.setlocale(locale.LC_ALL)
try:
yield locale.setlocale(locale.LC_ALL, name)
finally:
locale.setlocale(locale.LC_ALL, saved)
# Let's set a non-US locale
locale.setlocale(locale.LC_ALL, 'de_DE.UTF-8')
# Example to write a formatted English date
with setlocale('C'):
print(datetime.now().strftime('%a, %b')) # e.g. => "Thu, Jun"
# Example to read a formatted English date
with setlocale('C'):
mydate = datetime.strptime('Thu, Jun', '%a, %b')
Создает поточный менеджер контекста, используя глобальную блокировку, и позволяет вам иметь несколько потоков, выполняющих языковой код, используя LOCALE_LOCK. Он также обрабатывает исключения из инструкции yield, чтобы гарантировать, что исходный язык всегда восстанавливается.
взгляните на пакет pytz
, который вы можете использовать следующим образом:
import pytz
UTC = pytz.timezone('UTC') # utc
fr = pytz.timezone('Europe/Paris') #your local
from datetime import datetime
date = datetime.now(fr)
dateUTC = date.astimezone(UTC)
strftime будет отображаться в указанном часовом поясе
для названия месяца в языковой версии calendar , например:
import calendar
print calendar.month_name[dateUTC.month] #will print in the locale
проверить более глубокий календарь для получения дополнительной информации
calendar.month_name
Массив, который представляет месяцы года в текущей локали.
– Dima Tisnek
11 March 2015 в 13:14
Нет, нет способа вызвать strftime()
с определенной локалью.
Предполагая, что ваше приложение не является многопоточным, сохраните и восстановите существующий язык и установите для вашей локали значение 'C'
, когда вы вызываете strftime
.
#! /usr/bin/python3
import time
import locale
def get_c_locale_abbrev():
lc = locale.setlocale(locale.LC_TIME)
try:
locale.setlocale(locale.LC_TIME, "C")
return time.strftime("%a-%b")
finally:
locale.setlocale(locale.LC_TIME, lc)
# Let's suppose that we're french
locale.setlocale(locale.LC_ALL, 'fr_FR.utf8')
# Should print french, english, then french
print(time.strftime('%a-%b'))
print(get_c_locale_abbrev())
print(time.strftime('%a-%b'))
Если вы предпочитаете with:
- try:
- finally:
, вы можете разбить менеджер контекста:
#! /usr/bin/python3
import time
import locale
import contextlib
@contextlib.contextmanager
def setlocale(*args, **kw):
saved = locale.setlocale(locale.LC_ALL)
yield locale.setlocale(*args, **kw)
locale.setlocale(locale.LC_ALL, saved)
def get_c_locale_abbrev():
with setlocale(locale.LC_TIME, "C"):
return time.strftime("%a-%b")
# Let's suppose that we're french
locale.setlocale(locale.LC_ALL, 'fr_FR.utf8')
# Should print french, english, then french
print(time.strftime('%a-%b'))
print(get_c_locale_abbrev())
print(time.strftime('%a-%b'))
] locale.setlocale()
влияет на всю программу. Блок try-finally
или блок with
устанавливает и восстанавливает локаль, чтобы не нарушать остальную часть программы.
– Robᵩ
3 September 2013 в 15:22
saved = locale.setlocale(...
? – vonPetrushev 20 October 2014 в 19:57yield
, еслиsetlocale
выбрасывает? Разве это не беспорядок с конструкциейwith
? (например, преждевременныйStopIteration
поднят и т. д.) (И BTW - крутой ответ, там много чего происходит. Я думал, что проблема «locale is per process» не может быть отправлена так легко.) – Tomasz Gandor 25 April 2016 в 11:14