TRE=Tail Recursion Elimination 创始人是不愿意实现TRE的.他专门用了一篇文章来阐述原因. http://neopythonic.blogspot.com/2009/04/tail-recursion-elimination.html 1.不利于查BUG. 2.现有的1000递归深度够用. 3.递归不是所有编程的基础,也不是一个日常工具. 4.他举了个例子说明第四点,大概是指Python动态的特性不适合递归: def f(x): print 'original' i…
Python用上锁和解锁  lock lock.acquire lock.release 模拟抢火车票 import jsonimport timefrom multiprocessing import Process, Lock # with open('catalogue.json', 'w') as fp:# dic = {'total': 3}# json.dump(dic, fp) def check(buyers): with open('catalogue.json', mode=…
孤荷凌寒自学python第八十五天配置selenium并进行模拟浏览器操作1 (完整学习过程屏幕记录视频地址在文末) 要模拟进行浏览器操作,只用requests是不行的,因此今天了解到有专门的解决方案:selenium模块及与火狐浏览器的配合使用. 一.环境配置 (一).安装selenium模块 pip install selenium C:\WINDOWS\system32>pip install selenium Collecting selenium Downloading https:/…
Python开启尾递归优化 cpython本身不支持尾递归优化, 但是一个牛人想出的解决办法:实现一个 tail_call_optimized 装饰器 #!/usr/bin/env python2.4 # This program shows off a python decorator( # which implements tail call optimization. It # does this by throwing an exception if it is # it's own g…
# coding=utf-8 # Fibonacci.py Fib = {} def Fibonacci(n): global Fib if Fib.has_key(n): return Fib[n] if n == 0: return 1 if n == 1: return 1 Fib[n] = Fibonacci(n-1) + Fibonacci(n-2) return Fib[n] if __name__ == '__main__': for i in range(50): print F…
下面将使用WebDriver中的send_keys来模拟键盘按键输入 测试用例场景 send_keys方法可以模拟一些组合键操作: ctrl+a ctrl+c ctrl+v 等. 另外有时候我们需要在测试时使用tab键将焦点转移到下一个元素,这时候也需要send_keys.在某些更复杂的情况下,还会出现使用send_keys来模拟上下键来操作下拉列表的情况. Python脚本 测试HTML代码: <html> <head> <meta http-equiv="con…
爬前准备工作 在开始安装Appium之前,你要先知道Appium是做什么的?Appium 是一个自动化测试开源工具,看到没,做测试用的,它有点类似Selenium,可以自动操作APP实现一系列的操作. 标记重点,可以使用python对Appium编写脚本,实现对App的抓取. 今天就给你写一个100%叫你可以运行起来的入门实例. 下载地址 用稳定的最新版本即可. https://github.com/appium/appium-desktop/releases/tag/v1.10.0 下载之后,…
学习目的: selenium目前版本已经到了3代目,你想加薪,就跟面试官扯这个,你赢了,工资就到位了,加上一个脚本的应用,结局你懂的 正式步骤 需求背景:抓取淘宝美食 Step1:流程分析 搜索关键字:利用selenium驱动浏览器搜索关键字,得到查询后的商品列表 分析页码并翻页:得到商品页码数,模拟翻页,得到后续页面的商品列表 分析提取商品内容:利用PyQuery分析源码,解析得到商品列表 存储至MongoDB:将商品列表信息存储到数据库MongoDB Step2:代码分析 chromedri…
一.斐波那契数列 目标: 编写fib.py脚本,主要要求如下: 输出具有10个数字的斐波那契数列 使用for循环和range函数完成 改进程序,要求用户输入一个数字,可以生成用户需要长度的斐波那契数列 方案: 斐波那契数列就是某一个数,总是前两个数之和,比如0,1,1,2,3,5,8.由于输出是一串数字,可以用列表的结构存储.开始时,列表中有两个值,即0,1.然后通过循环向列表中追加元素,追加元素总是列表中最后两个元素值之和. 本例使用的是列表,不能使用元组,因为列表是一个可变类型,而元组是不可…
装饰器(decorator):为其他函数添加附加功能 原则:1.不修改被修饰函数源代码 2.不修改被修饰函数的调用方式 装饰器=高阶函数+函数嵌套+闭包 import time def timmer(func): def wapper(*args,**kwargs): start_time=time.time() res=func(*args,**kwargs) stop_time=time.time() print('函数运行时间是%s'%(stop_time-start_time)) ret…