本文整理匯總了Python中openpyxl.shared.date_time.SharedDate.from_julian方法的典型用法代碼示例。如果您正苦於以下問題:Python SharedDate.from_julian方法的具體用法?Python SharedDate.from_julian怎麽用?Python SharedDate.from_julian使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類openpyxl.shared.date_time.SharedDate
的用法示例。
在下文中一共展示了SharedDate.from_julian方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Cell
# 需要導入模塊: from openpyxl.shared.date_time import SharedDate [as 別名]
# 或者: from openpyxl.shared.date_time.SharedDate import from_julian [as 別名]
#.........這裏部分代碼省略.........
else:
time_search = self.RE_PATTERNS["time"].match(str(value))
if time_search:
sep_count = value.count(":") # pylint: disable=E1103
if sep_count == 1:
hours, minutes = [int(bit) for bit in value.split(":")] # pylint: disable=E1103
seconds = 0
elif sep_count == 2:
hours, minutes, seconds = [int(bit) for bit in value.split(":")] # pylint: disable=E1103
days = (hours / 24.0) + (minutes / 1440.0) + (seconds / 86400.0)
self.set_value_explicit(days, self.TYPE_NUMERIC)
self._set_number_format(NumberFormat.FORMAT_DATE_TIME3)
return True
if self._data_type == self.TYPE_NUMERIC:
# date detection
# if the value is a date, but not a date time, make it a
# datetime, and set the time part to 0
if isinstance(value, datetime.date) and not isinstance(value, datetime.datetime):
value = datetime.datetime.combine(value, datetime.time())
if isinstance(value, (datetime.datetime, datetime.time)):
if isinstance(value, datetime.datetime):
self._set_number_format(NumberFormat.FORMAT_DATE_YYYYMMDD2)
elif isinstance(value, datetime.time):
self._set_number_format(NumberFormat.FORMAT_DATE_TIME6)
value = SharedDate().datetime_to_julian(date=value)
self.set_value_explicit(value, self.TYPE_NUMERIC)
return True
self.set_value_explicit(value, self._data_type)
def _get_value(self):
"""Return the value, formatted as a date if needed"""
value = self._value
if self.is_date():
value = self._shared_date.from_julian(value)
return value
def _set_value(self, value):
"""Set the value and infer type and display options."""
self.bind_value(value)
value = property(
_get_value,
_set_value,
doc="Get or set the value held in the cell.\n\n"
":rtype: depends on the value (string, float, int or "
":class:`datetime.datetime`)",
)
def _set_hyperlink(self, val):
"""Set value and display for hyperlinks in a cell"""
if self._hyperlink_rel is None:
self._hyperlink_rel = self.parent.create_relationship("hyperlink")
self._hyperlink_rel.target = val
self._hyperlink_rel.target_mode = "External"
if self._value is None:
self.value = val
def _get_hyperlink(self):
"""Return the hyperlink target or an empty string"""
return self._hyperlink_rel is not None and self._hyperlink_rel.target or ""
hyperlink = property(
_get_hyperlink,
_set_hyperlink,
doc="Get or set the hyperlink held in the cell. "
"Automatically sets the `value` of the cell with link text, "
示例2: IterableWorksheet
# 需要導入模塊: from openpyxl.shared.date_time import SharedDate [as 別名]
# 或者: from openpyxl.shared.date_time.SharedDate import from_julian [as 別名]
class IterableWorksheet(Worksheet):
def __init__(self, parent_workbook, title, workbook_name,
sheet_codename, xml_source, string_table):
Worksheet.__init__(self, parent_workbook, title)
self.archive = zipfile.ZipFile(workbook_name, 'r')
self._workbook_name = workbook_name
self._sheet_codename = sheet_codename
self._string_table = string_table
min_col, min_row, max_col, max_row = read_dimension(xml_source=self.xml_source)
self.min_col = min_col
self.min_row = min_row
self.max_row = max_row
self.max_col = max_col
self._shared_date = SharedDate(base_date=parent_workbook.excel_base_date)
@property
def xml_source(self):
worksheet_path = '%s/%s' % (PACKAGE_WORKSHEETS, self._sheet_codename)
return self.archive.open(worksheet_path)
@xml_source.setter
def xml_source(self, value):
"""Base class is always supplied XML source, IteratableWorksheet obtains it on demand."""
pass
def __getitem__(self, key):
if isinstance(key, slice):
key = "{0}:{1}".format(key)
return self.iter_rows(key)
def iter_rows(self, range_string='', row_offset=0, column_offset=1):
""" Returns a squared range based on the `range_string` parameter,
using generators.
:param range_string: range of cells (e.g. 'A1:C4')
:type range_string: string
:param row_offset: additional rows (e.g. 4)
:type row: int
:param column_offset: additonal columns (e.g. 3)
:type column: int
:rtype: generator
"""
if range_string:
min_col, min_row, max_col, max_row = get_range_boundaries(range_string, row_offset, column_offset)
else:
min_col = column_index_from_string(self.min_col)
max_col = column_index_from_string(self.max_col) + 1
min_row = self.min_row
max_row = self.max_row + 6
return self.get_squared_range(min_col, min_row, max_col, max_row)
def get_squared_range(self, min_col, min_row, max_col, max_row):
expected_columns = [get_column_letter(ci) for ci in xrange(min_col, max_col)]
current_row = min_row
style_properties = read_style_table(self.archive.read(ARC_STYLE))
style_table = style_properties.pop('table')
for row, cells in groupby(self.get_cells(min_row, min_col,
max_row, max_col),
operator.attrgetter('row')):
full_row = []
if current_row < row:
for gap_row in xrange(current_row, row):
dummy_cells = get_missing_cells(gap_row, expected_columns)
yield tuple([dummy_cells[column] for column in expected_columns])
current_row = row
temp_cells = list(cells)
retrieved_columns = dict([(c.column, c) for c in temp_cells])
missing_columns = list(set(expected_columns) - set(retrieved_columns.keys()))
replacement_columns = get_missing_cells(row, missing_columns)
for column in expected_columns:
if column in retrieved_columns:
cell = retrieved_columns[column]
if cell.style_id is not None:
style = style_table[int(cell.style_id)]
cell = cell._replace(number_format=style.number_format.format_code) #pylint: disable-msg=W0212
if cell.internal_value is not None:
if cell.data_type in Cell.TYPE_STRING:
cell = cell._replace(internal_value=unicode(self._string_table[int(cell.internal_value)])) #pylint: disable-msg=W0212
elif cell.data_type == Cell.TYPE_BOOL:
cell = cell._replace(internal_value=cell.internal_value == '1')
elif cell.is_date:
cell = cell._replace(internal_value=self._shared_date.from_julian(float(cell.internal_value)))
elif cell.data_type == Cell.TYPE_NUMERIC:
cell = cell._replace(internal_value=float(cell.internal_value))
elif cell.data_type in(Cell.TYPE_INLINE, Cell.TYPE_FORMULA_CACHE_STRING):
cell = cell._replace(internal_value=unicode(cell.internal_value))
#.........這裏部分代碼省略.........
示例3: Cell
# 需要導入模塊: from openpyxl.shared.date_time import SharedDate [as 別名]
# 或者: from openpyxl.shared.date_time.SharedDate import from_julian [as 別名]
#.........這裏部分代碼省略.........
hours, minutes = [int(bit) for bit in value.split(':')] # pylint: disable=E1103
seconds = 0
elif sep_count == 2:
hours, minutes, seconds = \
[int(bit) for bit in value.split(':')] # pylint: disable=E1103
days = (hours / 24.0) + (minutes / 1440.0) + \
(seconds / 86400.0)
self.set_value_explicit(days, self.TYPE_NUMERIC)
self._set_number_format(NumberFormat.FORMAT_DATE_TIME3)
return True
if self._data_type == self.TYPE_NUMERIC:
# date detection
# if the value is a date, but not a date time, make it a
# datetime, and set the time part to 0
if isinstance(value, datetime.date) and not \
isinstance(value, datetime.datetime):
value = datetime.datetime.combine(value, datetime.time())
if isinstance(value, (datetime.datetime, datetime.time, datetime.timedelta)):
if isinstance(value, datetime.datetime):
self._set_number_format(NumberFormat.FORMAT_DATE_YYYYMMDD2)
elif isinstance(value, datetime.time):
self._set_number_format(NumberFormat.FORMAT_DATE_TIME6)
elif isinstance(value, datetime.timedelta):
self._set_number_format(NumberFormat.FORMAT_DATE_TIMEDELTA)
value = SharedDate().datetime_to_julian(date=value)
self.set_value_explicit(value, self.TYPE_NUMERIC)
return True
self.set_value_explicit(value, self._data_type)
def _get_value(self):
"""Return the value, formatted as a date if needed"""
value = self._value
if self.is_date():
value = self._shared_date.from_julian(value)
return value
def _set_value(self, value):
"""Set the value and infer type and display options."""
self.bind_value(value)
value = property(_get_value, _set_value,
doc='Get or set the value held in the cell.\n\n'
':rtype: depends on the value (string, float, int or '
':class:`datetime.datetime`)')
def _set_hyperlink(self, val):
"""Set value and display for hyperlinks in a cell"""
if self._hyperlink_rel is None:
self._hyperlink_rel = self.parent.create_relationship("hyperlink")
self._hyperlink_rel.target = val
self._hyperlink_rel.target_mode = "External"
if self._value is None:
self.value = val
def _get_hyperlink(self):
"""Return the hyperlink target or an empty string"""
return self._hyperlink_rel is not None and \
self._hyperlink_rel.target or ''
hyperlink = property(_get_hyperlink, _set_hyperlink,
doc='Get or set the hyperlink held in the cell. '
'Automatically sets the `value` of the cell with link text, '
'but you can modify it afterwards by setting the '
'`value` property, and the hyperlink will remain.\n\n'
':rtype: string')