分享

Python 基础语法(二)

韩克拉玛寒 发表于 2015-3-13 09:06:37 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 2 12431
本帖最后由 韩克拉玛寒 于 2015-3-17 14:09 编辑
问题导读:

1、如何理解Python的数据结构--元组、字典、序列、绑定等含义?








  2. 元组
    tuple和list十分相似,但是tuple是不可变的,即不能修改tuple,元组通过圆括号中用逗号分割的项定义;支持索引和切片操作;可以使用 in
  查看一个元素是否在tuple中。空元组();只含有一个元素的元组("a",) #需要加个逗号
    优点:tuple比list速度快;对不需要修改的数据进行‘写保护’,可以是代码更安全
    tuple与list可以相互转换,使用内置的函数list()和tuple()。
  1. l = [1, 2, 3]
  2. print l    # [1, 2, 3]
  3. t = tuple(l)
  4. print t   # (1, 2, 3)
  5. l1 = list(t)
  6. print l1  #[1, 2, 3]
复制代码

    元组最通常的用法是用在打印语句,如下例:
  1. name = "Peter Zhang"
  2. age = 25
  3. print "Name: %s; Age: %d" % (name, age)
  4. # Name: Peter Zhang; Age: 25
复制代码

    函数如下:
    count(value)  ---返回元组中值为value的元素的个数
  1. t = (1, 2, 3, 1, 2, 3)
  2. print t.count(2) # 2
复制代码

    index(value, [start, [stop]])  ---返回列表中第一个出现的值为value的索引,如果没有,则异常 ValueError
  1. t = (1, 2, 3, 1, 2, 3)
  2. print t.index(3) # 2
  3. try:
  4.      print t.index(4)
  5. except ValueError, ve:
  6.      print "there is no 4 in tuple"  # there is no 4 in tuple
复制代码

  3. 字典
    字典由键值对组成,键必须是唯一的;eg: d = {key1:value1, key2:value2};空字典用{}表示;字典中的键值对是没有顺序的,如果想要
  一个特定的顺序,那么使用前需要对它们排序;d[key] = value,如果字典中已有key,则为其赋值为value,否则添加新的键值对key/value;使
  用del d[key] 可以删除键值对;判断字典中是否有某键,可以使用in 或 not in;
  1. d = {}
  2. d["1"] = "one"
  3. d["2"] = "two"
  4. d["3"] = "three"
  5. del d["3"]
  6. for key, value in d.items():
  7.      print "%s --> %s" % (key, value)
  8. #1 --> one
  9. #2 --> two
复制代码

    dict函数如下:
    clear()  ---删除字典中所有元素
  1. d1 = {"1":"one", "2":"two"}
  2. d1.clear()
  3. print d1 # {}
复制代码

    copy()  ---返回字典的一个副本(浅复制)
  1. d1 = {"1":"one", "2":"two"}
  2. d2 = d1.copy()
  3. print d2 #{'1': 'one', '2': 'two'}
复制代码

    dict.fromkeys(seq,val=None) ---创建并返回一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值(默认为None)
  1. l = [1, 2, 3]
  2. t = (1, 2, 3)
  3. d3 = {}.fromkeys(l)
  4. print d3 #{1: None, 2: None, 3: None}
  5. d4 = {}.fromkeys(t, "default")
  6. print d4 #{1: 'default', 2: 'default', 3: 'default'}
复制代码

    get(key,[default])  ---返回字典dict中键key对应值,如果字典中不存在此键,则返回default 的值(default默认值为None)
  1. d5 = {1:"one", 2:"two", 3:"three"}
  2. print d5.get(1) #one
  3. print d5.get(5) #None
  4. print d5.get(5, "test") #test
复制代码

    has_key(key)  ---判断字典中是否有键key
  1. d6 = {1:"one", 2:"two", 3:"three"}
  2. print d6.has_key(1)  #True
  3. print d6.has_key(5)  #False
复制代码

    items()  ---返回一个包含字典中(键, 值)对元组的列表
  1. d7 = {1:"one", 2:"two", 3:"three"}
  2. for item in d7.items():
  3.     print item
  4. #(1, 'one')
  5. #(2, 'two')
  6. #(3, 'three')
  7. for key, value in d7.items():
  8.     print "%s -- %s" % (key, value)
  9. #1 -- one
  10. #2 -- two
  11. #3 -- three
复制代码

    keys()  ---返回一个包含字典中所有键的列表
  1. d8 = {1:"one", 2:"two", 3:"three"}
  2. for key in d8.keys():
  3.     print key
  4. #1
  5. #2
  6. #3
复制代码

    values()  ---返回一个包含字典中所有值的列表
  1. d8 = {1:"one", 2:"two", 3:"three"}
  2. for value in d8.values():
  3.     print value
  4. #one
  5. #two
  6. #three
复制代码

    pop(key, [default])  ---若字典中key键存在,删除并返回dict[key],若不存在,且未给出default值,引发KeyError异常
  1. d9 = {1:"one", 2:"two", 3:"three"}
  2. print d9.pop(1) #one
  3. print d9 #{2: 'two', 3: 'three'}
  4. print d9.pop(5, None) #None
  5. try:
  6.     d9.pop(5)  # raise KeyError
  7. except KeyError, ke:
  8.     print  "KeyError:", ke #KeyError:5
复制代码

    popitem()  ---删除任意键值对,并返回该键值对,如果字典为空,则产生异常KeyError
  1. d10 = {1:"one", 2:"two", 3:"three"}
  2. print d10.popitem()  #(1, 'one')
  3. print d10  #{2: 'two', 3: 'three'}
复制代码

    setdefault(key,[default])  ---若字典中有key,则返回vlaue值,若没有key,则加上该key,值为default,默认None
  1. d = {1:"one", 2:"two", 3:"three"}
  2. print d.setdefault(1)  #one
  3. print d.setdefault(5)  #None
  4. print d  #{1: 'one', 2: 'two', 3: 'three', 5: None}
  5. print d.setdefault(6, "six") #six
  6. print d  #{1: 'one', 2: 'two', 3: 'three', 5: None, 6: 'six'}
复制代码

    update(dict2)  ---把dict2的元素加入到dict中去,键字重复时会覆盖dict中的键值
  1. d = {1:"one", 2:"two", 3:"three"}
  2. d2 = {1:"first", 4:"forth"}
  3. d.update(d2)
  4. print d  #{1: 'first', 2: 'two', 3: 'three', 4: 'forth'}
复制代码

    viewitems()  ---返回一个view对象,(key, value)pair的列表,类似于视图。优点是,如果字典发生变化,view会同步发生变化。在
  迭代过程中,字典不允许改变,否则会报异常
  1. d = {1:"one", 2:"two", 3:"three"}
  2. for key, value in d.viewitems():
  3.      print "%s - %s" % (key, value)
  4. #1 - one
  5. #2 - two
  6. #3 - three
复制代码

    viewkeys()  ---返回一个view对象,key的列表
  1. d = {1:"one", 2:"two", 3:"three"}
  2. for key in d.viewkeys():
  3.      print key
  4. #1
  5. #2
  6. #3
复制代码

    viewvalues()  ---返回一个view对象,value的列表
  1. d = {1:"one", 2:"two", 3:"three"}
  2. for value in d.viewvalues():
  3.      print value
  4. #one
  5. #two
  6. #three
复制代码

  4. 序列
    序列类型是指容器内的元素从0开始的索引顺序访问,一次可以访问一个或者多个元素;列表、元组和字符串都是序列;序列的两个主要特点是
  索引操作符和切片操作符;索引可以得到特定元素;切片可以得到部分序列;
  1. numbers = ["zero", "one", "two", "three", "four"]
  2.   
  3.   print numbers[1] # one
  4.   print numbers[-1] # four
  5.   #print numbers[5] # raise IndexError
  6.   
  7.   print numbers[:] # ['zero', 'one', 'two', 'three', 'four']
  8.   print numbers[3:] # ['three', 'four']
  9.   print numbers[:2] # ['zero', 'one']
  10.   print numbers[2:4] # ['two', 'three']
  11.   print numbers[1:-1] # ['one', 'two', 'three']
复制代码

    切片操作符中的第一个数(冒号之前)表示切片开始的位置,第二个数(冒号之后)表示切片到哪里结束。 如果不指定第一个数,Python就从
  序列首开始。如果没有指定第二个数,则Python会停止在序列尾。 注意,返回的序列从开始位置 开始 ,刚好在结束位置之前 结束。即开始位置是
  包含在序列切片中的,而结束位置被排斥在切片外。 可以用负数做切片。负数用在从序列尾开始计算的位置。

  5. 绑定
    当创建一个对象并给它赋一个变量的时候,这个变量仅仅“指向”那个对象,而不是表示这个对象本身! 也就是说,变量名指向计算机中存储那个
  对象的内存,这被称作名称到对象的绑定。
    如果要复制一个列表或者类似的序列或者其他复杂的对象(不是如整数那样的简单对象),那么必须使用切片操作符来取得拷贝。



---------------------------------------------- 见续 Python 基础语法(三) ----------------------------------------------



来自群组: about云小组群
欢迎加入about云群425860289432264021 ,云计算爱好者群,亦可关注about云腾讯认证空间||关注本站微信

已有(2)人评论

跳转到指定楼层
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条