设为首页 收藏本站
查看: 708|回复: 0

[经验分享] python实用代码

[复制链接]

尚未签到

发表于 2017-4-24 09:19:41 | 显示全部楼层 |阅读模式
  1. python下载(http)文件并保存
  import urllib2
request = urllib2.Request("http://www.appchina.com/market/r/639017/com.sohu.inputmethod.sogou.apk?channel=aplus.direct&p=aplus.index&uid=gAJ9cQFVC3ZlcmlmeV9jb2RlcQJVBGt1dWxxA3Mu1UNbT0ifMPYMADcmCTSaFDqhBcjWwME7w&page=appplus.category&ref=appplus.main")
  response = urllib2.urlopen(request)
  #test
file_size = int(response.headers['content-length'])
print file_zise
  #test
  with open("E:\\tmp\\tmp.apk", 'wb') as output:
    while True:
        buffer = response.read(1024*256)
        if not buffer:
            break
        output.write(buffer)
  或者
  import urllib
import os

def reporthook(blocks_read, block_size, total_size):
    """total_size is reported in bytes.
    block_size is the amount read each time.
    blocks_read is the number of blocks successfully read.
    """
    if not blocks_read:
        print 'Connection opened'
        return

    if total_size < 0:
        # Unknown size
        print 'Read %d blocks (%d bytes)' % (blocks_read,
                                             blocks_read * block_size)

    else:
        amount_read = blocks_read * block_size
        print 'Read %d blocks, or %d/%d' % \
            (blocks_read, amount_read, total_size)
    return

try:
    filename, msg = urllib.urlretrieve(
        'http://blog.doughellmann.com/',
        reporthook=reporthook)
    print
    print 'File:', filename
    print 'Headers:'
    print msg
    print 'File exists before cleanup:', os.path.exists(filename)

finally:
    urllib.urlcleanup()

    print 'File still exists:', os.path.exists(filename)


  2. 线程示例
  import thread,time

count = 0
lock = thread.allocate_lock()

def threadTest():
    global count, lock
    #lock.acquire()
    for i in range(10000):
        count += 1
    #lock.release()
for i in range(10):
    thread.start_new_thread(threadTest, ())
time.sleep(3)
print count;
  3. threading的线程示例
  import threading,time,random

count = 0;

class ThreadClass(threading.Thread):
    def __init__(self, lock, threadName):
        threading.Thread.__init__(self, name = threadName)
        self.lock = lock
        print threadName

    def run(self):
        global count
        self.lock.acquire()
        for i in range(10000):
            count += 1
        print count
        self.lock.release()
       
lock = threading.Lock()
for i in range(10):
    ThreadClass(lock, "thread-" + str(i)).start()
time.sleep(3)
print count
  4. 队列应用
  import threading,Queue,time

queue = Queue.Queue(0)
SIZE = 15

class ThreadClass(threading.Thread):
    def __init__(self, job, type):
        super(ThreadClass, self).__init__()
        self.job = job
        self.type = type

    def run(self):
        while True:
            if self.job.qsize() > 0:
                data = self.job.get()
                taskfun(data, self.type)
            else:
                print
                print "thread-%s no job \n" %str(self.type)
                print
                break

def taskfun(data, type):
    time.sleep(1)
    print "data=%s,type=%s" %(str(data), str(type))

for j in range(3):
    queue.put(j)

print "queue size:%s" %str(queue.qsize())
for i in range(10):
    ThreadClass(queue, i).start()
time.sleep(5)

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-368442-1-1.html 上篇帖子: NIM(3), python 下篇帖子: python set函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表