Python入门(三)——list和tuple,条件判断和循环,dict和set
Python入门(三)——list和tuple,条件判断和循环,dict和set好的,我们继续来学习python,这次我们讲容器,也就是list,我们可以这样表示一.liststudent = ["zhangsan", "lisi", "wangwu"]print studentprint "长度为:",len(student)这样我们可以看下输出的内容我们可以看到打印的内容,以及他的长度是3,也
Python入门(三)——list和tuple,条件判断和循环,dict和set
好的,我们继续来学习python,这次我们讲容器,也就是list,我们可以这样表示
一.list
student = ["zhangsan", "lisi", "wangwu"]
print student
print "长度为:",len(student)
这样我们可以看下输出的内容
我们可以看到打印的内容,以及他的长度是3,也就是有三个子集,python中的list和java中的数组回去内容是一样的,但是他可以索引,以及可以随时的增加或者删除,我么可以看下
student = ["zhangsan", "lisi", "wangwu"]
print student[0]
print student[1]
print student[2]
print student[3]
从这个的表现手法,我们可以看出,list也是从0开始的,那这个下标3应该是不存在的,如果在Java中会报数组越界,那python尼?我们来看下
从输出的结果可以看出,他报了一个IndexError的错误,类似于数组越界
在python中,如果你想获取最后一个元素,你有两种办法,我们来看下
print student[len(student) - 1]
print student[-1]
我们可以长度-1,或者直接-1都是可以的,而且我们上面说过,list是可以增加,删除的,那我们来看下
student.append("liliu")
print student
这就是增加的操作,我们输出
可以看出,我们每一次增加默认都会在末尾,当然,他是一个灵活的容器,我们完全可以利用索引来插入
student.insert(1,"liliu")
print student
这句话的意思是我将这个元素插入在1的位置,索引输出的内容
既然如此,那我们还有删除,删除我们还是直接来看一段代码
student.insert(1, "liliu")
# 删除末尾
student.pop()
# 删除第一个
student.pop(0)
print student
从这段代码我们可以看出,删除最后一个可以直接调用函数pop,如果需要指定删除就添加索引就好了,这个还是比较好理解的
如果你想替换某一个元素,那就直接赋值就好了
student[0] = "Hello"
print student
这样第一个元素就替换了
这些和Java好像没什么不同。我们来看下不同,在python中,list可以可以放不同的数据类型哦,比如:
test = ["zhangsan", 1, 22, True, ["lisi", 123, 88, False]]
print test
可以发现,很神奇,因为里面可以包含很多的元素,连list都可以包含,如果你想去取list里面的list,我们可以这样那
print test[4][0]
这样就能拿到李四了
二.tuple
tuple和list很相似,但是他一旦确定了元素之后就不能变化了。所有这个才跟Java的数组很像才对。他也没有什么增加,删除的函数,因为他不变,所以安全性高
tuple的陷阱:当你定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来,比如:
test = (1, 2, 3)
print test
如果你想定义一个空的tuple,那么只要这样
test = ()
print test
而且我们可以定义tuple的元素
test = (5,)
print test
这里加个逗号是为了区分元素和长度,如果去掉这个逗号,我们会表示这是一个元素,这个元素是5
如果想让他可变的话,只要他的元素是list就好了
t = ('a', 'b', ['A', 'B'])
t[2][0] = "x"
t[2][1] = "y"
print t
其实他还是不变的,只是list变了而已
三.条件判断
条件判断,我们先来看下if语句
if age > 20:
print "成年人"
else:
print "未成年人"
好的,这段代码很简单,输出未成年人,但是如果现在有多个判断条件尼?
age = 38
if 50 > age > 20:
print "中年人"
elif age <= 18:
print "青少年"
elif age > 50:
print "老年人"
else:
print "儿童"
我们也是可以的,他的原则是
if <条件判断1>:
<执行1>
elif <条件判断2>:
<执行2>
elif <条件判断3>:
<执行3>
else:
<执行4>
四.循环
Python的循环有两种,一种是for…in循环,依次把list或tuple中的每个元素迭代出来,看例子:
names = ["张三", "李四", "王五"]
for name in names:
print name
这样就可以全部遍历出来了
所以for x in …循环就是把每个元素代入变量x,然后执行缩进块的语句。
再比如我们想计算1-10的整数之和,可以用一个sum变量做累加:
sum = 0
for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:
sum = sum + x
print sum
这样我们就可以输出总和55了
如果要计算1-100的整数之和,从1写到100有点困难,幸好Python提供一个range()函数,可以生成一个整数序列,比如range(5)生成的序列是从0开始小于5的整数,也就是0-4,那我们现在算100的话,应该是range(101)
sum = 0
for x in range(101):
sum = sum + x
print sum
这样我们就可以输出总和为5050
第二种循环是while循环,只要条件满足,就不断循环,条件不满足时退出循环。比如我们要计算100以内所有奇数之和,可以用while循环实现:
sum = 0
n = 99
while n > 0:
sum = sum + n
n = n - 2
print sum
这样就可以算出为2500
而一般的计算题都会结合输入来做一些处理的,比如
birthday = raw_input("请输入你的生日:\n")
if birthday > 2000:
print "00后"
else:
print "你不是老司机"
你们猜猜我输入1995会输出什么
是不是很奇怪,为什么会是输出00后,1995小于2000应该是输出你不是老司机呀
我们先来查下原因,我们加个打印
birthday = raw_input("请输入你的生日:\n")
print birthday
print birthday > 2000
if birthday > 2000:
print "00后"
else:
print "你不是老司机"
再来看下输出
你会发现他返回True,这是为什么尼?其实仔细想想,这个1995他其实是个字符串,因为我们raw_inpt输入的都是字符串,如果想整数计算,我们需要强转一下,比如这样
birthday = int(raw_input("请输入你的生日:\n"))
print birthday
print birthday > 2000
if birthday > 2000:
print "00后"
else:
print "你不是老司机"
这样就搞定了
五.dict
dict是词典的意思,但是在其他语言中,一般是map,因为是以键值对的形式成立的,我们来看下他的写法,用学生和分数来做:
d = {"张三": 59, "李四": 100, "王五": 88}
#我想知道李四的分数
print d["李四"]
键值对是以大括号的形式,如果想索引,就需要用他的key
当然,dict也是可以更改的,比如
d = {"zhangsan": 59, "lisi": 100, "wangwu": 88}
d["lisi"] = 50
print d
这样,我们看输出
你没有看错,李四的分数改了,如果不存在key ,那么会报错的KeyError,为了避免,我们可以用in去判断是否存在这个key
print "Hello" in d
他返回的就是一个布尔值
dict还提供了get方法供我们查询
print d.get("zhangsan")
要删除一个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
这里要注意一下,我们传入的是一个list,但是输出的,就不是一个list了,而是有1,2,3这三个元素
而且set有自动过滤的功能,我们来看下
s = set([1,2,3,2,3,3,3,5,2])
print s
这里的输出很有意思
可以看到,重复的元素都过滤掉了,也就是说set不允许有重复的key,set是支持增加和删除的
- add(key)
- remove(key)
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作,这也就是他所做的事情
>>> s1 = set([1, 2, 3])
>>> s2 = set([2, 3, 4])
>>> s1 & s2
set([2, 3])
>>> s1 | s2
set([1, 2, 3, 4])
set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。试试把list放入set,看看是否会报错。
最后来说一下一些小知识,比如list的排序
a = ["a", "c", "b"]
a.sort()
b = [1, 2, 3]
b.sort()
print a
print b
来看下他们的输出就好了
好了,python今天的基础就到这里了,可以发现我们把最基础的都差不多学会了,我们下一篇就开始了解函数了
更多推荐
所有评论(0)