4

私はこのpython記述子を持っています:

# Date Descriptor
class DateAttribute():
    def __init__(self, value=None):
        self.value = value
    def __get__(self, instance, value):
        return self.value
    def __set__(self, instance, value):
        if type(value) is not datetime.date: 
            raise TypeError('A date value is expected')
        self.value = value

およびこの記述子を使用するクラス D:

class D:
    thisdate = DateAttribute()

このクラスを次のように使用します。

x = D()
x.thisdate = datetime.date(2012, 9, 12)

記述子を拡張して、何らかの方法でフォーマットされた結果を提供したいと考えています。エス。

x.thisdate.format1
>>> '2012 9 12'
x.thisdate.format2
>>> '2012___9___12'
x.thisdate.format3
>>> '2012####9####12'
.....

私はこれを行うことができますか?

ありがとう

4

1 に答える 1

4

formatXプロパティをクラスに追加し、それに応じてフォーマットします。

class DateAttribute:
    ...

    @property
    def format1 (self): return self.value.strftime (SOMEFORMAT)

    @property
    def format2 (self): return self.value.strftime (SOMEOTHERFORMAT)

strftime 形式の文字列については、日時のドキュメントを参照してください

次のように機能します。

thisdate = DateAttribute (datetime.date (2012, 9, 12) )
print (thisdate.format1)

編集:

#! /usr/bin/python3

import datetime

class DateAttribute:
    def __init__(self, value=None):
        print ('initing')
        self.value = value

    def __get__(self, instance, value):
        print ('getting')
        if not self.value: return self.value
        return FormattedDate (self.value.year, self.value.month, self.value.day)

    def __set__(self, instance, value):
        print ('setting')
        if not isinstance (value, datetime.date): raise TypeError('A date value is expected')
        self.value = value


class FormattedDate (datetime.date):
    @property
    def format1 (self): return self.strftime ('%Y==%m==%d')

class D:
    thisdate = DateAttribute ()

d = D ()
print (d.thisdate)
d.thisdate = datetime.date (2013, 1, 1)
print (d.thisdate)
print (d.thisdate.format1)

次の出力が生成されます。

initing
getting
None
setting
getting
2013-01-01
getting
2013==01==01
于 2013-09-12T16:57:03.827 に答える