python中关于日期时间处理的问答集锦


Posted in Python onMarch 08, 2013

如何在安装setuptools模块时不生成egg压缩包而是源码

    Q:如何在安装setuptools模块时不生成egg压缩包而是源码,这样有时可以修改代码进行调试
    A:其实很简单,就在setup.py中的setup函数中增加 zip_safe=False, 参数即可。

    这样安装后的东西不再是一个egg文件了,而是象以前一样的目录结构。

    如何判断一个字符串只包含数字字符
    这是在 Python.list 邮件列表上看到的讨论

    Q:如何判断一个字符串只包含数字字符

    A:一种方法是 a.isdigit()。但这种方法对于包含正负号的数字字符串无效,因此更为准确的为:
        try:
            x = int(aPossibleInt)
            ... do something with x ...
        except ValueError:
            ... do something else ...

    这样更准确一些,适用性也更广。但如果你已经确信没有正负号,使用字符串的isdigit()方法则更为方便。

    知道某天,如何得到上星期的日期
    这是有人向我问的一个问题,记录在下面:

    Q: 我要写的小程序是这样的,写一个python脚本去返回上个星期的天数 in the format "YYYYMMDD"比如日期是20051122,返回结果是:["20051113", "20051114", "20051115", "20051116", "20051117", "20051118", "20051119"]

    A:首先将字符串的'yyyymmdd'转为 (year, mon, day),简单的可以:
         >>> date = '20051122'
         >>> year, mon, day = int(date[:4]), int(date[4:6]), int(date[6:])

    然后使用 datetime 得到一个 datetime 对象
         >>> import datetime
         >>> d = datetime.datetime(year, mon, day)
    因为 datetime 对象可以得到一个天数的星期日数(weekday),根据这个数向前推即可。
         >>> d.weekday()
         1

    文档上说,星期一是 0,则此上面就是星期二。看你的要求是从星期日开始算第一天,因此上个星期六就是:指定日期-它的星期日数-2
    知道星期六了,就知道上个星期的每天时间了
         >>> b = d - datetime.timedelta(d.weekday() + 2)
         >>> days = []
         >>> for i in range(6, -1, -1):
         ...   c = b - datetime.timedelta(i)
         ...   days.append(c.strftime('%Y%m%d'))
         >>> days
         ['20051113', '20051114', '20051115', '20051116', '20051117', '20051118', '20051119']

    如何截取指定长度的汉字

    Q: 我想截取一个指定长度的汉字串,但不想有半个汉字,如何做比较简单
    A: 可以考虑先按长度截取,然后转为unicode,如果成功就返回,如果失败,将长度减1返回即可。示例程序为:
        #coding=gbk
        def clip_hz(s, length):
            t = s[:length]
            try:
                unicode(t, 'gbk')
            except:
                t = s[:length-1]
            return t

        a = '中华人2民as共和国'
        if __name__ == '__main__':
            print clip_hz(a, 9)
            print clip_hz(a, 10)
            print clip_hz(a, 11)
            print clip_hz(a, 12)

    如何在Windows下方便地进入命令行运行程序

     在windows下的cmd窗口中执行python程序,我一般是这样做:

    1. 执行一个reg文件,内容为:

Windows Registry Editor Version 5.00 
[HKEY_CLASSES_ROOTDirectoryshellcmdcommand] 
@="cmd.exe /k "cd %L""

    它的作用是在你的资源管理器上的右键菜单上增加一个菜单,名字为cmd。那么以后你在目录栏中点击一个目录,然后点右键,再执行这个cmd菜单,就会直接进入这个目录的命令行。

    2. 因为已经进入了你的python程序所在的目录,因此直接在命令行下运行:
     Python yourprog.py  即可。

    前提是你已经将 Python 的安装目录加到 PATH 的环境变量中。

    重新设定包的搜索路径,以方便导入子模块
    也许这个题目有些唬人,不过实在不好表述,这是我在读 TaskCoach 时看到的一段代码。
    Q: 我有一个包,已经安装到了 Python 的 lib/site-packages 目录下,我可以通过 import x.sub 方式来导入 x 包的 sub 模块,但我想更方便的使用 import sub 来导入子模块,有没有这样的方法

    A: 要做一点简单的工作。
        import x

        libpath = x.__path__[0]
        sys.path.insert(0, libpath)
        del x

    先导入 x 包,得到它的路径,然后将这个路径加到sys.path(Python的模块搜索路径)的最前面。然后再将 x 模块删除即可。以后再导入 sub 时,可以只使用 import sub 来导入了。
    把这段代码加到启动代码中执行,以后就一直生效了。
    不过 TaskCoach 中不是使用 insert 来处理的,而是使用 append 来做的,这样我觉得不太好。因此如果在 x 包的前面有与你的子模块同名的模块就麻烦了,还是放在最前面保险。
    不过还可以使用 from x import sub 方式来导入,这样更易理解和标准一些。上述的技术是很有趣将其收录,看情况大家自已使用吧。

    子模块如何共享父模块的信息

    Q:一个模块A调用一个模块B,那么B如何访问模块A中的数据

    A:非常简单,在模块B中导入A模块即可

    其实这根本可以不认为是一个技巧,很多人也许就是这样做的。之所以写出来,只是提醒大家,你想到的可能就是可行的办法。因为之前我遇到过这样的问题,也想到这种方法,但感觉似乎并不好。但看了 CherryPy 的源码之后,它就是这样做的。因此我想这其实就是一种可行的办法。

    如何计算时间差

    Q:如何方便的计算两个时间的差,如两个时间相差几天,几小时等

    A:使用datetime模块可以很方便的解决这个问题,举例如下:
        >>> import datetime
        >>> d1 = datetime.datetime(2005, 2, 16)
        >>> d2 = datetime.datetime(2004, 12, 31)
        >>> (d1 - d2).days
        47
    上例演示了计算两个日期相差天数的计算。
        import datetime
        starttime = datetime.datetime.now()
        #long running
        endtime = datetime.datetime.now()
        print (endtime - starttime).seconds

    上例演示了计算运行时间的例子,以秒进行显示。
        >>> d1 = datetime.datetime.now()
        >>> d3 = d1 + datetime.timedelta(hours=10)
        >>> d3.ctime()
    上例演示了计算当前时间向后10小时的时间。

    其 本上常用的类有:datetime和timedelta两个。它们之间可以相互加减。每个类都有一些方法和属性可以查看具体的值,如datetime可以 查看:天数(day),小时数(hour),星期几(weekday())等;timedelta可以查看:天数(days),秒数(seconds) 等。

    如何取得用户的起始目录

    Q:我正在设计一个跨平台的应用,有没有一个统一的方法可以得到某个用户的起始目录

    A:用户的起始目录这里我指的是数据存放的目录,它根据用户的不同,可以由用户保存自已的数据。现在还没有一个统一的方式,下面是我看到的一个函数可以做这件事:
        def getHomeDir():
            ''' Try to find user's home directory, otherwise return current directory.'''
            try:
                path1=os.path.expanduser("~")
            except:
                path1=""
            try:
                path2=os.environ["HOME"]
            except:
                path2=""
            try:
                path3=os.environ["USERPROFILE"]
            except:
                path3=""

            if not os.path.exists(path1):
                if not os.path.exists(path2):
                    if not os.path.exists(path3):
                        return os.getcwd()
                    else: return path3
                else: return path2
            else: return path1

    在使用前记得导入os和os.path模块。

    查看unicode格式的数据

    Q:如果我有一个unicode格式的数据,如列表,如何才可以打印出可显示的格式,我不想看到u'uxxxx'这种样子
    A:我自已写了一个小函数,可以做这件事,只不过没有经过优化。我想如果想显示漂亮最好是修改pprint.py模块,用它用做,不过简单地用来调试应该够了。也许会有点用:)
        def uni_prt(a, encoding=None):
            import sys
            s = []
            if not encoding:
                encoding = sys.getdefaultencoding()
            if isinstance(a, (list, tuple)):
                if isinstance(a, list):
                    s.append('[')
                else:
                    s.append('(')
                for i, k in enumerate(a):
                    s.append(uni_prt(k, encoding))
                    if i<len(a)-1:
                        s.append(', ')
                if isinstance(a, list):
                    s.append(']')
                else:
                    s.append(')')
            elif isinstance(a, dict):
                for i, k in enumerate(a.items()):
                    key, value = k
                    s.append('{%s: %s}' % (uni_prt(key, encoding), uni_prt(value, encoding)))
                    if i<len(a.items())-1:
                        s.append(', ')
            elif isinstance(a, str):
                s.append("'%s'" %a)
            elif isinstance(a, unicode):
                s.append("'%s'" % a.encode(encoding))
            else:
                s.append(str(a))
            return ''.join(s)

    执行如:
    >>> a=unicode('中国', 'cp936')
    >>> print uni_prt([a]*3, 'cp936')
    ['中国', '中国', '中国']
第二个参数为unicode字符转换所使用的编码。缺省为系统缺省编码。

Python 相关文章推荐
python实现的各种排序算法代码
Mar 04 Python
python制作爬虫爬取京东商品评论教程
Dec 16 Python
Python中shape计算矩阵的方法示例
Apr 21 Python
Python调用ctypes使用C函数printf的方法
Aug 23 Python
Python 做曲线拟合和求积分的方法
Dec 29 Python
python验证身份证信息实例代码
May 06 Python
python绘制评估优化算法性能的测试函数
Jun 25 Python
python删除文件夹下相同文件和无法打开的图片
Jul 16 Python
PyQt5多线程刷新界面防假死示例
Dec 13 Python
Python使用gluon/mxnet模块实现的mnist手写数字识别功能完整示例
Dec 18 Python
利用Vscode进行Python开发环境配置的步骤
Jun 22 Python
Django model class Meta原理解析
Nov 14 Python
python局部赋值的规则
Mar 07 #Python
Python 用户登录验证的小例子
Mar 06 #Python
Eclipse + Python 的安装与配置流程
Mar 05 #Python
python将html转成PDF的实现代码(包含中文)
Mar 04 #Python
python发送邮件的实例代码(支持html、图片、附件)
Mar 04 #Python
python用ConfigObj读写配置文件的实现代码
Mar 04 #Python
Python编码时应该注意的几个情况
Mar 04 #Python
You might like
日本十大科幻动漫 宇宙骑士垫底,第一已成经典
2020/03/04 日漫
PHP压缩html网页代码(清除空格,换行符,制表符,注释标记)
2012/04/02 PHP
PHP 接入微信扫码支付总结(总结篇)
2016/11/03 PHP
PHP的mysqli_stat()函数讲解
2019/01/23 PHP
Thinkphp 框架扩展之驱动扩展实例分析
2020/04/27 PHP
SUN的《AJAX与J2EE》全文译了
2007/02/23 Javascript
jquery $.ajax入门应用二
2008/11/19 Javascript
JS 无法通过W3C验证的处理方法
2010/03/09 Javascript
javascript开发随笔一 preventDefault的必要
2011/11/25 Javascript
js中settimeout方法加参数的使用实例
2014/02/27 Javascript
JavaScript 性能优化小结
2015/10/12 Javascript
深入解析JavaScript编程中的this关键字使用
2015/11/09 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
jQuery拖拽通过八个点改变div大小
2020/11/29 Javascript
JS批量替换内容中关键词为超链接
2017/02/20 Javascript
js获取文件里面的所有文件名(实例)
2017/10/17 Javascript
vue项目在安卓低版本机显示空白的原因分析(两种)
2018/09/04 Javascript
Javascript实现时间倒计时功能
2018/11/17 Javascript
Vue动态生成el-checkbox点击无法赋值的解决方法
2019/02/21 Javascript
vue使用swiper实现中间大两边小的轮播图效果
2019/11/24 Javascript
jQuery实现视频展示效果
2020/05/30 jQuery
JS forEach跳出循环2种实现方法
2020/06/24 Javascript
如何手写简易的 Vue Router
2020/10/10 Javascript
[54:17]DOTA2-DPC中国联赛定级赛 RNG vs iG BO3第二场 1月10日
2021/03/11 DOTA
[01:11:28]DOTA2-DPC中国联赛定级赛 RNG vs Phoenix BO3第一场 1月8日
2021/03/11 DOTA
老生常谈python函数参数的区别(必看篇)
2017/05/29 Python
python实现给微信公众号发送消息的方法
2017/06/30 Python
Python基于贪心算法解决背包问题示例
2017/11/27 Python
浅谈Python实现贪心算法与活动安排问题
2017/12/19 Python
python将每个单词按空格分开并保存到文件中
2018/03/19 Python
详解django中使用定时任务的方法
2018/09/27 Python
python 用opencv调用训练好的模型进行识别的方法
2018/12/07 Python
python实现mask矩阵示例(根据列表所给元素)
2020/07/30 Python
党风廉政建设责任书
2014/04/14 职场文书
python blinker 信号库
2022/05/04 Python
Python创建SQL数据库流程逐步讲解
2022/09/23 Python