脚本专栏 
首页 > 脚本专栏 > 浏览文章

Python常用的内置序列结构(列表、元组、字典)学习笔记

(编辑:jimmy 日期: 2024/11/19 浏览:3 次 )

列表与元组
列表用大括号[]表示,元组用圆括号()表示。
列表可以修改,字符串与元组不可修改。
元组的分片还是元组,列表的分片还是列表。

1.列表方法:

name=["zhang3","li4","wang5"]
name.append("gou6") #添加项
name.remove("gou6") #移除第一个匹配项,也可用del name[3]来移除
name.insert(3,"gou6") #插入项
name.index("gou6") #找出第一个匹配项的位置
name.extend(["gou6","xuan7"]) #扩展
name.pop(0) #返回列表的第一项值并从列表中删除之

2.列表函数:

> a=list("hi guys") #把字符串转换为列表
> print a
['h', 'i', ' ', 'g', 'u', 'y', 's']
> ''.join(a)  #把列表还原成字符串
'hi guys'
> max(a) #取得列表的最大元素
'y'
> len(a) #取得列表长度
7
> min(a) #取得最小元素
' '
> tuple(a) #将列表转换为元组
('h', 'i', ' ', 'g', 'u', 'y', 's')
> sorted(a) #将列表元素排序
[' ', 'g', 'h', 'i', 's', 'u', 'y']

3.列表遍历:

A,使用for语句遍历

for each_item in name:
   print(each_item)

B,使用while语句遍历

i=0
while i < len(name):
   print(name[i])
   i += 1

4.成员资格1:

> sub="hello, you are a bear"
> "bear" in sub
True
> "y" in sub
True
> raw_input("what's your name") in sub
what's your name"htmlcode">
database=[
["zhang3","0111"],
["li4","0112"],
["wang5","0113"]
]
username=raw_input("what's your user name")
id=raw_input("what's your id")
if [username,id] in database: print "access granted"

6.找出10以内的整数

s = [x for x in range(0, 10) if x % 2 == 0]

7.生成九九乘法表

s = [(x, y, x*y) for x in range(1, 10) for y in range(1,10) if x>=y]

字符串

1.获取字符串 

name=raw_input("what's your name")
      print "Hello," + name + ".welcome to us"

注意:Pyhton3.x版本取消了raw_input,统一使用input
输出值:

print name + repr(x)
#str用于把值转换为合理的字符串,repr创建一个字符串,返回值的字符串形式
#str是一种类型(和int一样),repr是函数

2.换行符用\n表示
原始字符串,以字符串前加一个r即可,如

print r"c:\nowindows\no"
path="c:\nowindows\no"; print repr(path)

3.Unicode字符串

 print u"redhat"

注意:Pyhton3.x版本所有字符串都是unicode字符串
定义字符串时,双引号和单引号都是可以用的,只不过用单引号的时候可以在字符串里面使用双引号
布尔值:

> bool('i love you')
True
> bool(42)
True
> bool(1)
True
> bool('0')
True
> bool(0)
False
> bool('')
False

4.字符串方法

> tag="<a href=http://www.baidu.com>baidu indexpage</a>"
> print tag[8:28] #字符串分片
http://www.baidu.com
> print tag[29:-4] #字符串分片
baidu indexpage
> tag.replace("www.baidu.com","home.sina.com") #字符串替换
'<a href=http://home.sina.com>baidu indexpage</a>'

> dirs=["","usr","bin","env"]
> "/".join(dirs)  #将列表拼接成字符串
'/usr/bin/env'
> print ("C:" + "\\".join(dirs))
C:\usr\bin\env

> path="/usr/bin/env"
> path.split("/") #将字符串分割成列表
['', 'usr', 'bin', 'env']

5.其它字符串方法

> s=' I Love you!  '
> s.lower() #转换字符串的小写
' i love you!  '
> s.upper() #转换字符串的大写
' I LOVE YOU!  '
> s.title() #换换字符串为标题(所有单词首字母大写)
' I Love You!  '
> s.islower() #判断字符串是否为小写(也可判断大写和标题)
False
> s.strip()  #去除首尾空格,lstrip去除左边空格,rstrip去除右边空格
'I Love you!'
> word=s.split() #分割
> word
['I', 'Love', 'you!']
> '::'.join(word) #合并
'I::Love::you!'
> s.count('o') #统计出现次数
2
> s.find('you') #查找位置,如果找不到,则返回-1
9
> s.startswith('python')
False
> s.replace('you','yours')
' I Love yours!  '

上一篇:详解Python的collections模块中的deque双端队列结构
下一篇:简单掌握Python的Collections模块中counter结构的用法
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 SiteMap