跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. 【分享】读取excel表格日期问题

【分享】读取excel表格日期问题

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
2 帖子 1 发布者 2.1k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • 阿 离线
    阿 离线
    阿狸
    写于 最后由 编辑
    #1

    用xlrd读取excel表格中的日期,得到的是一串数字,比如日期为2014/5/4读出的是41763.0
    这是因为EXCEL的日期是以序列数的形式存储的,即保存的日期实际是这个日期到1900-1-1相差的天数。当单元格格式为数值时,就会显示出这个差值,即2006-12-1与1900-1-1相差39052天。
    那么如何把这串数字“翻译”成日期类型的呢?
    下面有两种方法,这里先感谢下重庆-mrshelly,南京-cdos,武汉-冰之星辰等热心的吧友提供的方法。

    1.用 datetime.timedelta函数,如:datetime.datetime(1900,1,1,0,0,0,0)-datetime.timedelta(days=2)+datetime.timedelta(days=41763)即可实现。(总监我直接复制粘贴了 ;D)
    该函数可以利用日期差来得到天数,正好适用该问题。更多用法可以百度下。
    2.利用xlrd自带的函数可以实现,具体如下:(cdos,我又复制粘贴了 ;))
    >>> import xlrd
    >>> import time
    >>> d = xlrd.open_workbook('e:\t1.xls')
    >>> table=d.sheets()[0]
    >>> print table.row_values(1)[0]
    41610.0
    >>> t = table.row_values(1)[0]
    >>> print xlrd.xldate_as_tuple(t,0)
    (2013, 12, 2, 0, 0, 0)
    >>>

    1 条回复 最后回复
    0

    • 登录

    • 没有帐号? 注册

    • 登录或注册以进行搜索。
    • 第一个帖子
      最后一个帖子
    0
    • 版块
    • 标签
    • 热门
    • 用户
    • 群组