Python小机制

  • collections.defaultdict()的使用

https://blog.csdn.net/yangsong95/article/details/82319675

  • time.time() vs. time.clock()

time.time()记录系统时间, time.clock()记录当前进程的CPU时间(至少Unix是如此)。前者可分析GPU阻塞/IO阻塞,后者只是分析程序运行时间。

https://stackoverflow.com/questions/85451/pythons-time-clock-vs-time-time-accuracy#85511

https://docs.python.org/3/library/timeit.html

  • 注意argparse中会将-解析成_:

    •     
      import argparse
      parser = argparse.ArgumentParser(description='PyTorch ImageNet Training')
      parser.add_argument('--opt-level', type=str)
      
      Out: _StoreAction(option_strings=['--opt-level'], dest='opt_level', nargs=None, const=None, default=None, type=<class 'str'>, choices=None, help=None, metavar=None)
      
  • a=b=c=1 这种赋值方式,其实是 a=1, b=a, c=a

  • List带下标的排序

a = [[3,1],[2,2],[7,3],[2,4],[5,5]]
a.sort()
def takeseconde(a):
    a[1]
a.sort(key=takeSecond)
Out[12]: [[2, 2], [2, 4], [3, 1], [5, 5], [7, 3]]

# Dict取极值
class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        num_dict = {}
        for num in nums:
            if num not in num_dict.keys():
                num_dict[num] = 1
            else:
                num_dict[num] += 1
        return max(num_dict, key=num_dict.get)

连接字符串数组。将字符串、元组、列表中的元素和字典名以指定的字符(分隔符)连接生成一个新的字符串。

  • enumerate()函数

# 下面anns是list,ann是字典,ann也会改变anns的值
for id, ann in enumerate(anns):
    bb = ann['bbox']
    x1, x2, y1, y2 = [bb[0], bb[0]+bb[2], bb[1], bb[1]+bb[3]]
    if not 'segmentation' in ann:
        ann['segmentation'] = [[x1, y1, x1, y2, x2, y2, x2, y1]]
        ann['area'] = bb[2]*bb[3]
        ann['id'] = id+1
        ann['iscrowd'] = 0
  • 生成requirements.txt文件

    pip freeze > requirements.txt

    安装requirements.txt依赖

    pip install -r requirements.txt
  • assert expression [, arguments]:

    python assert断言是声明其布尔值必须为真的判定,如果发生异常就说明表达示为假。可以理解assert断言语句为raise-if-not,用来测试表示式,其返回值为假,就会触发异常

  • embed()

from IPython import embed
embed()

程序运行到插入embed语句的地方时,会转到 IPython 环境下。之后可以逐个浏览当前状态下的各个变量,调用各种函数,输出你感兴趣的值来帮助调试。之后你可以照常退出 IPython,然后程序会继续运行下去,自然地你在当时 IPython 下执行的语句也会对程序接下来的运行造成影响。

这个方法是在这里(http://lukeplant.me.uk/blog/posts/exploratory-programming-with-ipython/)看到的。想象一下,这样做就像让高速运转的程序暂停下来,你再对运行中的程序进行检查和修改,之后再让他继续运行下去。这里举一个例子,比如编写网页 bot ,你在每取回一个页面后你都得看看它的内容,再尝试如何处理他获得下一个页面的地址。运用这个技巧,你可以在取回页面后让程序中断,再那里实验各种处理方 法,在找到正确的处理方式后写回到你的代码中,再进行下一步。这种工作流程只有像 Python 这种动态语言才可以做到。

  • sys.path模块,动态的修改系统路径(仅在程序生命周期内有效)

def AddSysPath(new_path):  
      """ AddSysPath(new_path):给Python的sys.path增加一个"目录"  
      如果此目录不存在或者已经在sys.path中了,则不操作  
      返回1表示成功,-1表示new_path不存在,0表示已经在sys.path中了  
      already on sys.path.  
      """  
      import sys, os  
      # 避免加入一个不存在的目录  
      if not os.path.exists(new_path): return -1  
      # 将路径标准化。 Windows是大小写不敏感的,所以若确定在  
      # Windows下,将其转成小写  
      new_path = os.path.abspath(new_path)  
      if sys.platform == 'win32':  
            new_pathnew_path = new_path.lower( )  
      # 检查当前所有的路径  
      for x in sys.path:  
            x = os.path.abspath(x)  
            if sys.platform == 'win32':  
                   xx = x.lower( )  
            if new_path in (x, x + os.sep):  
                   return 0  
      sys.path.append(new_path)  
      # 如果想让new_path在sys.path处于最前  
      # 使用:sys.path.insert(0, new_path)  
      return 1  
if _ _name_ _ == '_ _main_ _':  
      # 测试,显示用法  
      import sys  
      print 'Before:'  
      for x in sys.path: print x  
      if sys.platform == 'win32':  
              print AddSysPath('c:\\Temp')  
              print AddSysPath('c:\\temp')  
    else:  
              print AddSysPath('/usr/lib/my_modules')  
      print 'After:'  
      for x in sys.path: print x 
--------------------- 
作者:Cche1 
来源:CSDN 
原文:https://blog.csdn.net/qq_27923041/article/details/72878635 
版权声明:本文为博主原创文章,转载请附上博文链接!
  • os.system, Execute the command (a string) in a subshell.
  • os.mkdir(), os.remove();
  • os.path模块

 Python OS 文件/目录方法主要用于获取文件的属性

os.path.abspath(path) #返回绝对路径
os.path.basename(path) #返回文件名
os.path.commonprefix(list) #返回list(多个路径)中,所有path共有的最长的路径。
os.path.dirname(path) #返回文件路径
os.path.exists(path)  #路径存在则返回True,路径损坏返回False
os.path.lexists  #路径存在则返回True,路径损坏也返回True
os.path.expanduser(path)  #把path中包含的"~"和"~user"转换成用户目录
os.path.expandvars(path)  #根据环境变量的值替换path中包含的”$name”和”${name}”
os.path.getatime(path)  #返回最后一次进入此path的时间。
os.path.getmtime(path)  #返回在此path下最后一次修改的时间。
os.path.getctime(path)  #返回path的大小
os.path.getsize(path)  #返回文件大小,如果文件不存在就返回错误
os.path.isabs(path)  #判断是否为绝对路径
os.path.isfile(path)  #判断路径是否为文件
os.path.isdir(path)  #判断路径是否为目录
os.path.islink(path)  #判断路径是否为链接
os.path.ismount(path)  #判断路径是否为挂载点()
os.path.join(path1[, path2[, ...]])  #把目录和文件名合成一个路径
os.path.normcase(path)  #转换path的大小写和斜杠
os.path.normpath(path)  #规范path字符串形式
os.path.realpath(path)  #返回path的真实路径
os.path.relpath(path[, start])  #从start开始计算相对路径
os.path.samefile(path1, path2)  #判断目录或文件是否相同
os.path.sameopenfile(fp1, fp2)  #判断fp1和fp2是否指向同一文件
os.path.samestat(stat1, stat2)  #判断stat tuple stat1和stat2是否指向同一个文件
os.path.split(path)  #把路径分割成dirname和basename,返回一个元组
os.path.splitdrive(path)   #一般用在windows下,返回驱动器名和路径组成的元组
os.path.splitext(path)  #分割路径,返回路径名和文件扩展名的元组
os.path.splitunc(path)  #把路径分割为加载点与文件
os.path.walk(path, visit, arg)  #遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数;
os.path.supports_unicode_filenames  #设置是否支持unicode路径名

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值