|
5 | 5 | import operator as op
|
6 | 6 | from functools import partial
|
7 | 7 | from itertools import product, islice, chain
|
| 8 | +from datetime import datetime |
8 | 9 |
|
9 | 10 | import numpy as np
|
10 | 11 |
|
@@ -161,24 +162,16 @@ def raw(self):
|
161 | 162 | self.type))
|
162 | 163 |
|
163 | 164 | @property
|
164 |
| - def kind(self): |
| 165 | + def is_datetime(self): |
165 | 166 | try:
|
166 |
| - return self.type.__name__ |
| 167 | + t = self.type.type |
167 | 168 | except AttributeError:
|
168 |
| - return self.type.type.__name__ |
| 169 | + t = self.type |
| 170 | + |
| 171 | + return issubclass(t, (datetime, np.datetime64)) |
169 | 172 |
|
170 | 173 | @property
|
171 | 174 | def value(self):
|
172 |
| - kind = self.kind.lower() |
173 |
| - if kind == 'datetime64': |
174 |
| - try: |
175 |
| - return self._value.asi8 |
176 |
| - except AttributeError: |
177 |
| - return self._value.view('i8') |
178 |
| - elif kind == 'datetime': |
179 |
| - return pd.Timestamp(self._value) |
180 |
| - elif kind == 'timestamp': |
181 |
| - return self._value.asm8.view('i8') |
182 | 175 | return self._value
|
183 | 176 |
|
184 | 177 | @value.setter
|
@@ -248,6 +241,15 @@ def return_type(self):
|
248 | 241 | def isscalar(self):
|
249 | 242 | return all(operand.isscalar for operand in self.operands)
|
250 | 243 |
|
| 244 | + @property |
| 245 | + def is_datetime(self): |
| 246 | + try: |
| 247 | + t = self.return_type.type |
| 248 | + except AttributeError: |
| 249 | + t = self.return_type |
| 250 | + |
| 251 | + return issubclass(t, (datetime, np.datetime64)) |
| 252 | + |
251 | 253 |
|
252 | 254 | def _in(x, y):
|
253 | 255 | """Compute the vectorized membership of ``x in y`` if possible, otherwise
|
@@ -424,24 +426,20 @@ def stringify(value):
|
424 | 426 |
|
425 | 427 | lhs, rhs = self.lhs, self.rhs
|
426 | 428 |
|
427 |
| - if (is_term(lhs) and lhs.kind.startswith('datetime') and is_term(rhs) |
428 |
| - and rhs.isscalar): |
| 429 | + if is_term(lhs) and lhs.is_datetime and is_term(rhs) and rhs.isscalar: |
429 | 430 | v = rhs.value
|
430 | 431 | if isinstance(v, (int, float)):
|
431 | 432 | v = stringify(v)
|
432 |
| - v = _ensure_decoded(v) |
433 |
| - v = pd.Timestamp(v) |
| 433 | + v = pd.Timestamp(_ensure_decoded(v)) |
434 | 434 | if v.tz is not None:
|
435 | 435 | v = v.tz_convert('UTC')
|
436 | 436 | self.rhs.update(v)
|
437 | 437 |
|
438 |
| - if (is_term(rhs) and rhs.kind.startswith('datetime') and |
439 |
| - is_term(lhs) and lhs.isscalar): |
| 438 | + if is_term(rhs) and rhs.is_datetime and is_term(lhs) and lhs.isscalar: |
440 | 439 | v = lhs.value
|
441 | 440 | if isinstance(v, (int, float)):
|
442 | 441 | v = stringify(v)
|
443 |
| - v = _ensure_decoded(v) |
444 |
| - v = pd.Timestamp(v) |
| 442 | + v = pd.Timestamp(_ensure_decoded(v)) |
445 | 443 | if v.tz is not None:
|
446 | 444 | v = v.tz_convert('UTC')
|
447 | 445 | self.lhs.update(v)
|
|
0 commit comments