खोज…


परिचय

Timezones अक्सर डेवलपर्स के लिए एक परेशानी है। Django अपने निपटान में कुछ बेहतरीन उपयोगिताओं प्रदान करता है ताकि टाइमज़ोन के साथ काम करना आसान हो सके।

भले ही आपका प्रोजेक्ट एक ही समय क्षेत्र में चल रहा हो, फिर भी दिन के उजाले की बचत के मामलों को संभालने के लिए अपने डेटाबेस में यूटीसी के रूप में डेटा स्टोर करना अच्छा है। यदि आप कई टाइमज़ोन पर काम कर रहे हैं तो यूटीसी के रूप में समय डेटा संग्रहीत करना आवश्यक है।

समय क्षेत्र समर्थन सक्षम करें

सबसे पहले, यह सुनिश्चित करें कि USE_TZ = True आपकी settings.py में USE_TZ = True है। TIME_ZONE जैसे TIME_ZONE='UTC' लिए एक डिफ़ॉल्ट समय क्षेत्र मान भी सेट करें। यहां टाइमज़ोन की एक पूरी सूची देखें।

यदि USE_TZ गलत है, तो TIME_ZONE वह समय क्षेत्र होगा जो Django सभी USE_TZ को संग्रहीत करने के लिए उपयोग करेगा। जब USE_TZ सक्षम होता है, TIME_ZONE डिफ़ॉल्ट समय क्षेत्र है जो Django टेम्पलेट्स में USE_TZ प्रदर्शित करने और रूपों में दर्ज किए गए USE_TZ की व्याख्या करने के लिए उपयोग करेगा।

समय क्षेत्र समर्थन सक्षम होने के साथ, django डेटाबेस में डेटा datetime को UTC रूप में संग्रहीत करेगा

सत्र टाइमज़ोन की स्थापना

पायथन के datetime.datetime वस्तुओं में एक tzinfo विशेषता है जो समय क्षेत्र की जानकारी संग्रहीत करने के लिए उपयोग की जाती है। जब विशेषता सेट की जाती है तो वस्तु को Aware माना जाता है, जब विशेषता सेट नहीं होती है तो इसे Naive माना जाता है।

यह सुनिश्चित करने के लिए कि एक समय क्षेत्र भोला या जागरूक है, आप .is_naive() और .is_aware() उपयोग कर सकते हैं।

यदि आपके पास USE_TZ अपने में सक्षम settings.py फ़ाइल, एक datetime समय क्षेत्र में लंबे समय के रूप में इसे से जुड़ी जानकारी होगी के रूप में अपने डिफ़ॉल्ट TIME_ZONE में सेट है settings.py

हालांकि यह डिफ़ॉल्ट समय क्षेत्र कुछ मामलों में अच्छा हो सकता है, यह विशेष रूप से पर्याप्त नहीं है, खासकर यदि आप उपयोगकर्ताओं को कई समय क्षेत्रों में संभाल रहे हैं। इसे पूरा करने के लिए, मिडलवेयर का उपयोग किया जाना चाहिए।

import pytz

from django.utils import timezone

# make sure you add `TimezoneMiddleware` appropriately in settings.py
class TimezoneMiddleware(object):
    """
    Middleware to properly handle the users timezone
    """

    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        # make sure they are authenticated so we know we have their tz info.
        if request.user.is_authenticated():
            # we are getting the users timezone that in this case is stored in 
            # a user's profile
            tz_str = request.user.profile.timezone
            timezone.activate(pytz.timezone(tz_str))
        # otherwise deactivate and the default time zone will be used anyway
        else:
            timezone.deactivate()

        response = self.get_response(request)
        return response

कुछ नई चीजें चल रही हैं। मिडलवेयर के बारे में अधिक जानने के लिए और यह दस्तावेज़ीकरण के उस हिस्से की जाँच करता है। __call__ हम __call__ डेटा की सेटिंग को संभाल रहे हैं। पहले हम यह सुनिश्चित करते हैं कि उपयोगकर्ता प्रमाणित है, यह सुनिश्चित करने के लिए कि हमारे पास इस उपयोगकर्ता के लिए समय क्षेत्र डेटा है। एक बार जब हम जानते हैं कि हम कर लेते हैं, तो हम timezone.activate() का उपयोग करके उपयोगकर्ता सत्र के लिए टाइमज़ोन को सक्रिय करते हैं। टाइम ज़ोन स्ट्रिंग को परिवर्तित करने के लिए हमें pytz.timezone(str) द्वारा प्रयोग करने योग्य कुछ करना होगा, हम pytz.timezone(str) उपयोग करते हैं।

अब, जब डेटाटाइम ऑब्जेक्ट्स को टेम्प्लेट में एक्सेस किया जाता है, तो वे डेटाबेस के 'UTC' प्रारूप से स्वचालित रूप से परिवर्तित हो जाएंगे, उपयोगकर्ता जिस भी समय क्षेत्र में है, बस डेटाइम ऑब्जेक्ट तक पहुँचें और इसका टाइमज़ोन सेट किया जाएगा मानकर पिछले मिडलवेयर सेट किया गया है। ठीक से।

{{ my_datetime_value }}

यदि आप उपयोगकर्ता के टाइमज़ोन का उपयोग करने के लिए एक अच्छा दानेदार नियंत्रण चाहते हैं, तो निम्नलिखित पर एक नज़र डालें:

{% load tz %}
{% localtime on %}
    {# this time will be respect the users time zone #}
    {{ your_date_time }}
{% endlocaltime %}

{% localtime off %}
    {# this will not respect the users time zone #}
    {{ your_date_time }}
{% endlocaltime %}

ध्यान दें, वर्णित यह विधि केवल Django 1.10 और में काम करती है। 1.10 से पहले django का समर्थन करने के लिए MiddlewareMixin में देखें



Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow