Python笔记(叁)继续学习

主题:
为什么要有方法呢?
回答居然是:懒惰是一种美德
方法的定义关键词:
  def
用callable来判断是否是可调用:


代码如下:

x = 1
y = math.sqrt
callable(x) #False
callable(y) #True

关于方法的返回值:


代码如下:

def hello(name):
return 'Hello, ' + name + '!'

有一个算法的实现:前面两个数的和是后面的数


代码如下:

fibs = [0, 1]
for i in range(8):
fibs.append(fibs[-2] + fibs[-1])

result:[0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

如此就可以定义一个方法实现:


代码如下:

def fibs(num):
result = [0, 1]
for i in range(num-2):
result.append(result[-2] + result[-1])
return result

跳出方法中命令的执行:


代码如下:

def test():
print 'This is printed'
return
print 'This is not'

如果方法没有返回任何东西的话,返回的是None
关于方法的参数
我们传入方法的参数是否被改变的问题,在很多语言中都会遇到。

例子:


代码如下:

def try_to_change(n):
n = 'Mr. Gumby'

name = 'Mrs. Entity'
try_to_change(name)
name # 'Mrs. Entity'

上面的例子参数没有被改变,那么那些参数是可变的呢。
String number tuples 是作为不可变的类型,我们不能改变它们。如果我们使用可变的类型作为参数就可以实现参数在方法内被改变的功能了。


代码如下:

def change(n):
n[0] = 'Mr. Gumby'

names = ['Mrs. Entity', 'Mrs. Thing']
change(names)
names #['Mr. Gumby', 'Mrs. Thing']

这部分内容其实类似于java,我以前有个博文:猛击即可到达

方法传参,可以通过以下的方式解决参数意思的混淆:


代码如下:

def hello_1(greeting, name):
print '%s, %s!' % (greeting, name)
hello_1(greeting='Hello', name='world') #Hello, world!

一个更具名字找人的方法集:


代码如下:

def init(data): #1
data['first'] = {}
data['middle'] = {}
data['last'] = {}

def lookup(data, label, name):
return data[label].get(name)#2

def store(data, full_name):
names = full_name.split()#3
if len(names) == 2: names.insert(1, '')#4
labels = 'first', 'middle', 'last'
for label, name in zip(labels, names):#5
people = lookup(data, label, name)
if people:
people.append(full_name)#6
else:
data[label][name] = [full_name]

使用:


代码如下:

MyNames = {}
init(MyNames)
store(MyNames, 'Magnus Lie Hetland')
lookup(MyNames, 'middle', 'Lie') #['Magnus Lie Hetland']

理解:

1,data 的数据结构式这样的:{'middle': {}, 'last': {}, 'first': {}}
2,get方法根据建找到值
3,string的split方法,可以加入分隔符,默认是空格为分隔符:


代码如下:

test = 'a,2,d'
test.split(',') #['a', '2', 'd']
name = 'my xy dd'
names = name.split()
names #['my', 'xy', 'dd']

4,insert插入的时候后面的值向后退,不要理解成替换


代码如下:

names.insert(1, '')
names #['my', '', 'xy', 'dd']

5,zip方法说明的例子:


代码如下:

x = [1, 2, 3]
y = [4, 5, 6]
zipped = zip(x, y)#(1, 4), (2, 5), (3, 6)

6,这个label里已经存在查找的name了,就把full name加上去
关于参数中的 * 和 **

  * :表示任意个数的参数

  **  :表示dictionary参数

例子:


代码如下:

def print_params_2(title, *params):
print title
print params
print_params_2('Params:', 1, 2, 3)

结果是

Params:
(1, 2, 3)


代码如下:

def print_params(**params):
print params
print_params(x=1, y=2, z=3)

结果是:{'z': 3, 'x': 1, 'y': 2}
结合*可以改进刚刚的存储名字的方法:


代码如下:

def store(data, *full_names):
for full_name in full_names:
names = full_name.split()
if len(names) == 2: names.insert(1, '')
labels = 'first', 'middle', 'last'
for label, name in zip(labels, names):
people = lookup(data, label, name)
if people:
people.append(full_name)
else:
data[label][name] = [full_name]

调用:


代码如下:

d = {}
init(d)
store(d, 'Han Solo')
store(d, 'Luke Skywalker', 'Anakin Skywalker')
lookup(d, 'last', 'Skywalker')#['Luke Skywalker', 'Anakin Skywalker']

总结:

工作中虽然用不到,但是抽点时间学习,充实自己也不错哦。
笔记可以用来翻看学习,希望未来的我看到这里的时候,不要气馁,不要骄狂,一点一滴的学习,可能将来没有用,但耐心的本事也许就是需要这样的方式锻炼出来的。
让我们继续前行!

(0)

相关推荐

  • python笔记(2)

    继续List: 删除元素: 复制代码 代码如下: a =[1, 2, 3, 4] a[2:3] = [] #[1, 2, 4] del a[2] #[1, 2] 清空list 复制代码 代码如下: a[ : ] = [] del a[:] list作为栈使用(后入先出): 复制代码 代码如下: stack = [3, 4, 5] stack.append(6) stack.append(7) stack.pop() # 7 stack.pop() # 6 stack.pop() # 5 用负数索

  • python笔记(1) 关于我们应不应该继续学习python

    以前面试的时候会被问到,linux熟不熟呀?对于这种问题:我总会尴尬地回答,"额..了解一点". 然而,我大学毕业的时候,连linux的虚拟机都没装过,更别提系统熟不熟悉了.虽然我了解一点这个系统可以完全通过命令来操作.后来工作了,有时候写点代码,svn提交上去,服务器是Linux的,自己也是在windows上跑跑客户端.记得有个项目,要求用shell来启动java程序,你知道那时候我是怎么做的吗?把他们的shell拿来,问哪几个地方要改的,然后改下要启动java类的路径.ok了,完全

  • Python笔记(叁)继续学习

    主题: 为什么要有方法呢? 回答居然是:懒惰是一种美德 方法的定义关键词: def 用callable来判断是否是可调用: 复制代码 代码如下: x = 1 y = math.sqrt callable(x) #False callable(y) #True 关于方法的返回值: 复制代码 代码如下: def hello(name): return 'Hello, ' + name + '!' 有一个算法的实现:前面两个数的和是后面的数 复制代码 代码如下: fibs = [0, 1] for i

  • Python正规则表达式学习指南

    1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎,效率上可能不如str自带的方法,但功能十分强大.得益于这一点,在提供了正则表达式的语言里,正则表达式的语法都是一样的,区别只在于不同的编程语言实现支持的语法数量不同:但不用担心,不被支持的语法通常是不常用的部分.如果已经在其他语言里使用过正则表达式,只需要简单看一看就可以上手了. 下图展示了使用正则表达式进行匹配的流程: 正则表达式的大致

  • python笔记:mysql、redis操作方法

    模块安装: 数据操作用到的模块pymysql,需要通过pip install pymysql进行安装. redis操作用的模块是redis,需要通过pip install redis进行安装. 检验是否安装成功:进入到Python命令行模式,输入import pymysql. import redis ,无报错代表成功: mysql操作方法如下: 查询数据:fetchone.fetchmany(n).fetchall() import pymysql #建立mysql连接,ip.端口.用户名.密

  • Python装饰器入门学习教程(九步学习)

    装饰器(decorator)是一种高级Python语法.装饰器可以对一个函数.方法或者类进行加工.在Python中,我们有多种方法对函数和类进行加工,比如在Python闭包中,我们见到函数对象作为某一个函数的返回结果.相对于其它方式,装饰器语法简单,代码可读性高.因此,装饰器在Python项目中有广泛的应用. 这是在Python学习小组上介绍的内容,现学现卖.多练习是好的学习方式. 第一步:最简单的函数,准备附加额外功能 # -*- coding:gbk -*- '''示例1: 最简单的函数,表

  • Python中装饰器学习总结

    本文研究的主要内容是Python中装饰器相关学习总结,具体如下. 装饰器(decorator)功能 引入日志 函数执行时间统计 执行函数前预备处理 执行函数后清理功能 权限校验等场景 缓存 装饰器示例 例1:无参数的函数 from time import ctime, sleep def timefun(func): def wrappedfunc(): print("%s called at %s"%(func.__name__, ctime())) func() return wr

  • python使用tensorflow深度学习识别验证码

    本文介绍了python使用tensorflow深度学习识别验证码 ,分享给大家,具体如下: 除了传统的PIL包处理图片,然后用pytessert+OCR识别意外,还可以使用tessorflow训练来识别验证码. 此篇代码大部分是转载的,只改了很少地方. 代码是运行在linux环境,tessorflow没有支持windows的python 2.7. gen_captcha.py代码. #coding=utf-8 from captcha.image import ImageCaptcha # pi

  • Python爬虫包BeautifulSoup学习实例(五)

    本文为大家分享了Python爬虫包BeautifulSoup学习实例,具体内容如下 BeautifulSoup 使用BeautifulSoup抓取豆瓣电影的一些信息. # -*- coding: utf-8 -*- # @Author: HaonanWu # @Date: 2016-12-24 16:18:01 # @Last Modified by: HaonanWu # @Last Modified time: 2016-12-24 17:25:33 import urllib2 impor

  • python笔记_将循环内容在一行输出的方法

    例子是输出九九乘法表 如果按照如下程序写: # 输出九九乘法表 for i in range(10): for j in range(1,i+1): print("{}*{}={:2} ".format(j,i,i*j)) print('') 就会出现下面的输出: 这并不是我们想要的形式.print()会自动换行. python3中end属性默认为换行符\n,此时将end属性改为'',就不会自动换行了. 只需要将 print("{}*{}={:2} ".format

  • python入门之算法学习

    前言 参考学习书籍:<算法图解>[美]Aditya Bhargava,袁国忠(译)北京人民邮电出版社,2017 二分查找 binary_search 实现二分查找的python代码如下: def binary_search(list, item): low = 0 #最低位索引位置为0 high = len(list)- 1 #最高位索引位置为总长度-1 while low <= high: mid = (low + high)//2 #检查中间的元素,书上是一条斜杠,我试过加两条斜杠才

随机推荐