数据结构基本上就是——它们是可以处理一些 数据 的 结构 。或者说,它们是用来存储一组相关数据的。

在Python中有三种内建的数据结构——列表、元组和字典。我们将会学习如何使用它们,以及它们如何使编程变得简单。

列表

list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个 序列 的项目。假想你有一个购物列表,上面记载着你要买的东西,你就容易理解列表了。只不过在你的购物表上,可能每样东西都独自占有一行,而在Python中,你在每个项目之间用逗号分割。

列表中的项目应该包括在方括号中,这样Python就知道你是在指明一个列表。一旦你创建了一个列表,你可以添加、删除或是搜索列表中的项目。由于你可以增加或删除项目,我们说列表是 可变的 数据类型,即这种类型是可以被改变的。
例9.1 使用列表

#!/usr/bin/python
 # Filename: using_list.py

 # This is my shopping list
 shoplist = ['apple', 'mango', 'carrot', 'banana']

 print 'I have', len(shoplist),'items to purchase.'

 print 'These items are:', # Notice the comma at end of the line
 for item in shoplist:
     print item,

 print '/nI also have to buy rice.'
 shoplist.append('rice')
 print 'My shopping list is now', shoplist

 print 'I will sort my list now'
 shoplist.sort()
 print 'Sorted shopping list is', shoplist

 print 'The first item I will buy is', shoplist[0]
 olditem = shoplist[0]
 del shoplist[0]
 print 'I bought the', olditem
 print 'My shopping list is now', shoplist



元组和列表十分类似,只不过元组和字符串一样是 不可变的 即你不能修改元组。元组通过圆括号中用逗号分割的项目定义。元组通常用在使语句或用户定义的函数能够安全地采用一组值的时候,即被使用的元组的值不会改变。
使用元组

例9.2 使用元组

#!/usr/bin/python
 # Filename: using_tuple.py

 zoo = ('wolf', 'elephant', 'penguin')
 print 'Number of animals in the zoo is', len(zoo)

 new_zoo = ('monkey', 'dolphin', zoo)
 print 'Number of animals in the new zoo is', len(new_zoo)
 print 'All animals in new zoo are', new_zoo
 print 'Animals brought from old zoo are', new_zoo[2]
 print 'Last animal brought from old zoo is', new_zoo[2][2]



字典类似于你通过联系人名字查找地址和联系人详细情况的地址簿,即,我们把键(名字)和值(详细情况)联系在一起。注意,键必须是唯一的,就像如果有两个人恰巧同名的话,你无法找到正确的信息。

注意,你只能使用不可变的对象(比如字符串)来作为字典的键,但是你可以不可变或可变的对象作为字典的值。基本说来就是,你应该只使用简单的对象作为键。

键值对在字典中以这样的方式标记:d = {key1 : value1, key2 : value2 }。注意它们的键/值对用冒号分割,而各个对用逗号分割,所有这些都包括在花括号中。

记住字典中的键/值对是没有顺序的。如果你想要一个特定的顺序,那么你应该在使用前自己对它们排序。

字典是dict类的实例/对象。
使用字典

例9.4 使用字典

#!/usr/bin/python

 a={
     'sandflee':'fxj',
     'shuiling':'wyl'    
   } 
 print a['shuiling']
 a['child']='haoran'
 print a
 print a['child']
 for na,na2 in a.items():
     print'%s  %s' %(na,na2)
 if 'shuiling' in a:
     print "shuiling's name is %s"% a['shuiling']

 just a dream,so....


序列

列表、元组和字符串都是序列,但是序列是什么,它们为什么如此特别呢?序列的两个主要特点是索引操作符和切片操作符。索引操作符让我们可以从序列中抓取一个特定项目。切片操作符让我们能够获取序列的一个切片,即一部分序列。
----------就是一个索引,-1代表右边第一个  字典也可以看作以键值作为索引

使用序列

例9.5 使用序列

#!/usr/bin/python
 # Filename: seq.py

 shoplist = ['apple', 'mango', 'carrot', 'banana']

 # Indexing or 'Subscription' operation
 print 'Item 0 is', shoplist[0]
 print 'Item 1 is', shoplist[1]
 print 'Item 2 is', shoplist[2]
 print 'Item 3 is', shoplist[3]
 print 'Item -1 is', shoplist[-1]
 print 'Item -2 is', shoplist[-2]

 # Slicing on a list
 print 'Item 1 to 3 is', shoplist[1:3]
 print 'Item 2 to end is', shoplist[2:]
 print 'Item 1 to -1 is', shoplist[1:-1]
 print 'Item start to end is', shoplist[:]

 # Slicing on a string
 name = 'swaroop'
 print 'characters 1 to 3 is', name[1:3]
 print 'characters 2 to end is', name[2:]
 print 'characters 1 to -1 is', name[1:-1]
 print 'characters start to end is', name[:]



我们已经在前面详细讨论了字符串。我们还需要知道什么呢?那么,你是否知道字符串也是对象,同样具有方法。这些方法可以完成包括检验一部分字符串和去除空格在内的各种工作。

你在程序中使用的字符串都是str类的对象。这个类的一些有用的方法会在下面这个例子中说明。如果要了解这些方法的完整列表,请参见help(str)。
字符串的方法

例9.7 字符串的方法

#!/usr/bin/python
 # Filename: str_methods.py

 name = 'Swaroop' # This is a string object

 if name.startswith('Swa'):
     print 'Yes, the string starts with "Swa"'

 if 'a' in name:
     print 'Yes, it contains the string "a"'

 if name.find('war') != -1:
     print 'Yes, it contains the string "war"'

 delimiter = '_*_'
 mylist = ['Brazil', 'Russia', 'India', 'China']
 print delimiter.join(mylist)