python函数

来源:互联网 发布:软件贵金属喊单室 编辑:程序博客网 时间:2024/05/22 01:48

Python入门(三)——list和tuple,条件判断和循环,dict和set

作者:qq_26787115

Python入门(三)——list和tuple,条件判断和循环,dict和set


好的,我们继续来学习python,这次我们讲容器,也就是list,我们可以这样表示

一.list

student = ["zhangsan", "lisi", "wangwu"]print studentprint "长度为:",len(student)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

这样我们可以看下输出的内容

这里写图片描述

我们可以看到打印的内容,以及他的长度是3,也就是有三个子集,python中的list和java中的数组回去内容是一样的,但是他可以索引,以及可以随时的增加或者删除,我么可以看下

student = ["zhangsan", "lisi", "wangwu"]print student[0]print student[1]print student[2]print student[3]
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

从这个的表现手法,我们可以看出,list也是从0开始的,那这个下标3应该是不存在的,如果在Java中会报数组越界,那python尼?我们来看下

这里写图片描述

从输出的结果可以看出,他报了一个IndexError的错误,类似于数组越界

在python中,如果你想获取最后一个元素,你有两种办法,我们来看下

print student[len(student) - 1]print student[-1]
  • 1
  • 2
  • 3

我们可以长度-1,或者直接-1都是可以的,而且我们上面说过,list是可以增加,删除的,那我们来看下

student.append("liliu")print student
  • 1
  • 2
  • 3

这就是增加的操作,我们输出

这里写图片描述

可以看出,我们每一次增加默认都会在末尾,当然,他是一个灵活的容器,我们完全可以利用索引来插入

student.insert(1,"liliu")print student
  • 1
  • 2
  • 3

这句话的意思是我将这个元素插入在1的位置,索引输出的内容

这里写图片描述

既然如此,那我们还有删除,删除我们还是直接来看一段代码

student.insert(1, "liliu")# 删除末尾student.pop()# 删除第一个student.pop(0)print student
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

从这段代码我们可以看出,删除最后一个可以直接调用函数pop,如果需要指定删除就添加索引就好了,这个还是比较好理解的

如果你想替换某一个元素,那就直接赋值就好了

student[0] = "Hello"print student
  • 1
  • 2
  • 3

这样第一个元素就替换了

这些和Java好像没什么不同。我们来看下不同,在python中,list可以可以放不同的数据类型哦,比如:

test = ["zhangsan", 1, 22, True, ["lisi", 123, 88, False]]print test
  • 1
  • 2
  • 3

可以发现,很神奇,因为里面可以包含很多的元素,连list都可以包含,如果你想去取list里面的list,我们可以这样那

print test[4][0]
  • 1

这样就能拿到李四了

二.tuple

tuple和list很相似,但是他一旦确定了元素之后就不能变化了。所有这个才跟Java的数组很像才对。他也没有什么增加,删除的函数,因为他不变,所以安全性高

tuple的陷阱:当你定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来,比如:

test = (1, 2, 3)print test
  • 1
  • 2
  • 3

如果你想定义一个空的tuple,那么只要这样

test = ()print test
  • 1
  • 2
  • 3
  • 4

而且我们可以定义tuple的元素

test = (5,)print test
  • 1
  • 2
  • 3

这里加个逗号是为了区分元素和长度,如果去掉这个逗号,我们会表示这是一个元素,这个元素是5

如果想让他可变的话,只要他的元素是list就好了

t = ('a', 'b', ['A', 'B'])t[2][0] = "x"t[2][1] = "y"print t
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

其实他还是不变的,只是list变了而已

三.条件判断

条件判断,我们先来看下if语句

if age > 20:    print "成年人"else:    print "未成年人"
  • 1
  • 2
  • 3
  • 4

好的,这段代码很简单,输出未成年人,但是如果现在有多个判断条件尼?

age = 38if 50 > age > 20:    print "中年人"elif age <= 18:    print "青少年"elif age > 50:    print "老年人"else:    print "儿童"
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

我们也是可以的,他的原则是

if <条件判断1>:    <执行1>elif <条件判断2>:    <执行2>elif <条件判断3>:    <执行3>else:    <执行4>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

四.循环

Python的循环有两种,一种是for…in循环,依次把list或tuple中的每个元素迭代出来,看例子:

names = ["张三", "李四", "王五"]for name in names:    print name
  • 1
  • 2
  • 3
  • 4

这样就可以全部遍历出来了

所以for x in …循环就是把每个元素代入变量x,然后执行缩进块的语句。

再比如我们想计算1-10的整数之和,可以用一个sum变量做累加:

sum = 0for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:    sum = sum + xprint sum
  • 1
  • 2
  • 3
  • 4

这样我们就可以输出总和55了

如果要计算1-100的整数之和,从1写到100有点困难,幸好Python提供一个range()函数,可以生成一个整数序列,比如range(5)生成的序列是从0开始小于5的整数,也就是0-4,那我们现在算100的话,应该是range(101)

sum = 0for x in range(101):    sum = sum + xprint sum
  • 1
  • 2
  • 3
  • 4

这样我们就可以输出总和为5050

第二种循环是while循环,只要条件满足,就不断循环,条件不满足时退出循环。比如我们要计算100以内所有奇数之和,可以用while循环实现:

sum = 0n = 99while n > 0:    sum = sum + n    n = n - 2print sum
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

这样就可以算出为2500

而一般的计算题都会结合输入来做一些处理的,比如

birthday = raw_input("请输入你的生日:\n")if birthday > 2000:    print "00后"else:    print "你不是老司机"
  • 1
  • 2
  • 3
  • 4
  • 5

你们猜猜我输入1995会输出什么 
这里写图片描述

是不是很奇怪,为什么会是输出00后,1995小于2000应该是输出你不是老司机呀

我们先来查下原因,我们加个打印

birthday = raw_input("请输入你的生日:\n")print birthdayprint birthday > 2000if birthday > 2000:    print "00后"else:    print "你不是老司机"
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

再来看下输出

这里写图片描述

你会发现他返回True,这是为什么尼?其实仔细想想,这个1995他其实是个字符串,因为我们raw_inpt输入的都是字符串,如果想整数计算,我们需要强转一下,比如这样

birthday = int(raw_input("请输入你的生日:\n"))print birthdayprint birthday > 2000if birthday > 2000:    print "00后"else:    print "你不是老司机"
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

这样就搞定了

五.dict

dict是词典的意思,但是在其他语言中,一般是map,因为是以键值对的形式成立的,我们来看下他的写法,用学生和分数来做:

d = {"张三": 59, "李四": 100, "王五": 88}#我想知道李四的分数print d["李四"]
  • 1
  • 2
  • 3
  • 4

键值对是以大括号的形式,如果想索引,就需要用他的key

当然,dict也是可以更改的,比如

d = {"zhangsan": 59, "lisi": 100, "wangwu": 88}d["lisi"] = 50print d
  • 1
  • 2
  • 3
  • 4
  • 5

这样,我们看输出

这里写图片描述

你没有看错,李四的分数改了,如果不存在key ,那么会报错的KeyError,为了避免,我们可以用in去判断是否存在这个key

print "Hello" in d
  • 1

他返回的就是一个布尔值

dict还提供了get方法供我们查询

print d.get("zhangsan")
  • 1

要删除一个key,只需要调用pop(key)就好了

和list比较,dict有以下几个特点:

  • 查找和插入的速度极快,不会随着key的增加而增加;
  • 需要占用大量的内存,内存浪费多。

而list相反:

  • 查找和插入的时间随着元素的增加而增加;
  • 占用空间小,浪费内存很少。

所以,dict是用空间来换取时间的一种方法。

六.set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

要创建一个set,需要提供一个list作为输入集合:

s = set([1,2,3])print s
  • 1
  • 2
  • 3

这里要注意一下,我们传入的是一个list,但是输出的,就不是一个list了,而是有1,2,3这三个元素

而且set有自动过滤的功能,我们来看下

s = set([1,2,3,2,3,3,3,5,2])print s
  • 1
  • 2
  • 3

这里的输出很有意思

这里写图片描述

可以看到,重复的元素都过滤掉了,也就是说set不允许有重复的key,set是支持增加和删除的

  • add(key)
  • remove(key)

set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作,这也就是他所做的事情

>>> s1 = set([1, 2, 3])>>> s2 = set([2, 3, 4])>>> s1 & s2set([2, 3])>>> s1 | s2set([1, 2, 3, 4])
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。试试把list放入set,看看是否会报错。

最后来说一下一些小知识,比如list的排序

a = ["a", "c", "b"]a.sort()b = [1, 2, 3]b.sort()print aprint b
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

来看下他们的输出就好了

这里写图片描述

好了,python今天的基础就到这里了,可以发现我们把最基础的都差不多学会了,我们下一篇就开始了解函数了

原创粉丝点击