python相似模块用例


Posted in Python onMarch 04, 2016

一:threading VS Thread

众所周知,python是支持多线程的,而且是native的线程,其中threading是对Thread模块做了包装,可以更加方面的被使用,threading模块里面主要对一些线程操作对象化了,创建了Thread的类。

使用线程有两种模式,一种是创建线程要执行的函数,把这个函数传递进Thread对象里,让它来执行,一种是直接从Thread继承,创建一个新的class,把线程执行的代码放到这个新的类里面,用例如下:

①使用Thread来实现多线程

#!/usr/bin/env python
#-*- coding:utf-8 -*-

import string
import threading 
import time

def threadMain(a):
  global count,mutex
  #获得线程名
  threadname = threading.currentThread().getName()

  for x in xrange(0,int(a)):
    #获得锁
    mutex.acquire()
    count += 1
    #释放锁
    mutex.release()
    print threadname,x,count
    time.sleep()

def main(num):
  global count,mutex
  threads = []
  count = 1
  #创建一个锁
  mutex = threading.Lock()
  #先创建线程对象
  for x in xrange(0,num):
    threads.append(threading.Thread(target = threadMain,args=(10,)))
  for t in threads:
    t.start()
  for t in threads:
    t.join()

if __name__ == "__main__":
  num = 4
  main(num);

②使用threading来实现多线程

#!/usr/bin/env python
#-*- coding:utf-8 -*-

import threading
import time

class Test(threading.Thread):
  def __init__(self,num):
    threading.Thread.__init__(self):
    self._run_num = num

  def run(self):
    global count,mutex
    threadName = threading.currentThread.getName()
    for x in xrange(0,int(self._run_num)):
      mutex.acquire()
      count += 1
      mutex.release()
      print threadName,x,count
      time.sleep(1)

if __name__ == "__main__":
  global count,mutex
  threads = []
  num = 4
  count = 1
  mutex.threading.Lock()
  for x in xrange(o,num):
    threads.append(Test(10))
  #启动线程
  for t in threads:
    t.start()
  #等待子线程结束
  for t in threads:
    t.join()

二:optparser VS getopt

①使用getopt模块处理Unix模式的命令行选项

getopt模块用于抽出命令行选项和参数,也就是sys.argv,命令行选项使得程序的参数更加灵活,支持短选项模式和长选项模式

例:python scriptname.py ?f “hello” ?directory-prefix=”/home” ?t  --format ‘a'‘b'

getopt函数的格式:getopt.getopt([命令行参数列表],‘短选项',[长选项列表])

其中短选项名后面的带冒号(:)表示该选项必须有附加的参数

长选项名后面有等号(=)表示该选项必须有附加的参数

返回options以及args

options是一个参数选项及其value的元组((‘-f','hello'),(‘-t',''),(‘—format',''),(‘—directory-prefix','/home'))

args是除去有用参数外其他的命令行 输入(‘a',‘b')

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import sys
import getopt

def Usage():
  print "Usage: %s [-a|-0|-c] [--help|--output] args..."%sys.argv[0]

if __name__ == "__main__":
  try:
    options,args = getopt.getopt(sys.argv[1:],"ao:c",['help',"putput="]):
    print options
    print "\n"
    print args

    for option,arg in options:
      if option in ("-h","--help"):
        Usage()
        sys.exit(1)
      elif option in ('-t','--test'):
        print "for test option"
      else:
        print option,arg
  except getopt.GetoptError:
    print "Getopt Error"
    Usage()
    sys.exit(1)

②optparser模块

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import optparser
def main():
  usage = "Usage: %prog [option] arg1,arg2..."
  parser = OptionParser(usage=usage)
  parser.add_option("-v","--verbose",action="store_true",dest="verbose",default=True,help="make lots of noise [default]")
  parser.add_option("-q","--quiet",action="store_false",dest="verbose",help="be vewwy quiet (I'm hunting wabbits)")
  parser.add_option("-f","--filename",metavar="FILE",help="write output to FILE")
  parser.add_option("-m","--mode",default="intermediate",help="interaction mode: novice, intermediate,or expert [default: %default]")
  (options,args) = parser.parse_args()
  if len(args) != 1:
    parser.error("incorrect number of arguments")
  if options.verbose:
    print "reading %s..." %options.filename 

if __name__ == "__main__":
  main()

以上就是threading VS Thread、optparser VS getopt 的相互比较,希望对大家学习模块有所帮助。

Python 相关文章推荐
Python3.2中Print函数用法实例详解
May 19 Python
使用Python中的tkinter模块作图的方法
Feb 07 Python
Python中turtle作图示例
Nov 15 Python
TensorFlow高效读取数据的方法示例
Feb 06 Python
matplotlib 纵坐标轴显示数据值的实例
May 25 Python
python通过http下载文件的方法详解
Jul 26 Python
利用python计算windows全盘文件md5值的脚本
Jul 27 Python
Python3的unicode编码转换成中文的问题及解决方案
Dec 10 Python
Python实现大数据收集至excel的思路详解
Jan 03 Python
Python实现企业微信机器人每天定时发消息实例
Feb 25 Python
在pycharm中关掉ipython console/PyDev操作
Jun 09 Python
PyCharm2019 安装和配置教程详解附激活码
Jul 31 Python
Python程序中用csv模块来操作csv文件的基本使用教程
Mar 03 #Python
举例简单讲解Python中的数据存储模块shelve的用法
Mar 03 #Python
Python中的数据对象持久化存储模块pickle的使用示例
Mar 03 #Python
Python和Perl绘制中国北京跑步地图的方法
Mar 03 #Python
python套接字流重定向实例汇总
Mar 03 #Python
Python设计模式中单例模式的实现及在Tornado中的应用
Mar 02 #Python
Python使用设计模式中的责任链模式与迭代器模式的示例
Mar 02 #Python
You might like
php 时间计算问题小结
2009/01/04 PHP
PHP中spl_autoload_register函数的用法总结
2013/11/07 PHP
PHP设计模式之装饰器模式实例详解
2018/02/07 PHP
实例讲解PHP中使用命名空间
2019/01/27 PHP
jquery.autocomplete修改实现键盘上下键自动填充示例
2013/11/19 Javascript
jQuery中die()方法用法实例
2015/01/19 Javascript
微信企业号开发之微信考勤Cookies的使用
2015/09/11 Javascript
12个非常实用的JavaScript小技巧【推荐】
2016/05/18 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
JS填写银行卡号每隔4位数字加一个空格
2016/12/19 Javascript
Angular2使用jQuery的方法教程
2017/05/28 jQuery
浅谈Node.js ORM框架Sequlize之表间关系
2017/07/24 Javascript
web前端页面生成exe可执行文件的方法
2018/02/08 Javascript
解决Js先触发失去焦点事件再执行点击事件的问题
2018/08/30 Javascript
微信小程序实现传递多个参数与事件处理
2019/08/12 Javascript
vue - vue.config.js中devServer配置方式
2019/10/30 Javascript
javascript canvas封装动态时钟
2020/09/30 Javascript
[57:53]DOTA2上海特级锦标赛主赛事日 - 2 败者组第二轮#3OG VS VP
2016/03/03 DOTA
[45:18]完美世界DOTA2联赛循环赛 PXG vs IO 第二场 11.06
2020/11/09 DOTA
简单的通用表达式求10乘阶示例
2014/03/03 Python
Python实现输出某区间范围内全部素数的方法
2018/05/02 Python
python 将数据保存为excel的xls格式(实例讲解)
2018/05/03 Python
Python实现的括号匹配判断功能示例
2018/08/25 Python
解决Python下json.loads()中文字符出错的问题
2018/12/19 Python
tensorflow实现对张量数据的切片操作方式
2020/01/19 Python
Python逐行读取文件内容的方法总结
2020/02/14 Python
解决pyinstaller打包运行程序时出现缺少plotly库问题
2020/06/02 Python
详解Python中的GIL(全局解释器锁)详解及解决GIL的几种方案
2021/01/29 Python
HTML5 Canvas阴影使用方法实例演示
2013/08/02 HTML / CSS
师德学习感言
2014/01/31 职场文书
保险公司演讲稿
2014/09/02 职场文书
律师授权委托书范本
2014/10/07 职场文书
教师师德师风整改措施
2014/10/24 职场文书
临床医学生职业规划书范文
2014/10/25 职场文书
群众路线四风对照检查材料
2014/11/04 职场文书
2014年维修电工工作总结
2014/11/20 职场文书