python数据类型: int 类型 float 小数类型 string 字符串 布尔类型 a = True b = False
1.列表,也称数组或list或array。它的表达方式通过下标或索引或编号来呈现。students=[‘张三‘,‘李四‘,‘王五‘,‘赵六‘]print(students[0])注:最前面一个元素的下标为0,最后面一个元素的下标为-1
cities = []
#增加:(两种方式)cities.append(‘北京‘) 在列表的末尾增加一个元素cities.insert(0,‘上海‘) 在列表的指定位置增加一个元素 #删除:cities.pop(1) 删除指定位置的元素cities.remove(‘北京‘) 删除指定的元素cities.clear() 清除listdel cities(0) 删除指定位置元素 #修改:cities[-1]=‘南京‘ 修改指定位置的元素,若指定的位置不存在会报错 #查询:print(cities[1]) 查询指定位置元素print(cities.index(‘广州‘)) 获取元素的下标,如果找不到指定元素会报错print(cities.count(‘广州‘)) 获取指定元素在list出现的次数 #.inverse() 反转,把list反转一下new_lis=[‘hello‘,‘world‘]print(new_lis.verse()) #.sortnums=[3,2,5,7,1,0]nums.sort() #排序,升序nums.sort(reverse=True) 降cities2=[‘武汉‘]#print(cities + cities2) 合并list
#print(cities *3) 复制3次 #多维数组words=[‘view‘,‘code‘,‘tools‘,[‘price‘,‘num‘,198,[‘hello‘,‘usa‘,‘吃鸡‘]] ]print(words[-1][-1][1]) #切片,切片是list取值的一种方式(切片操作同样也适用于字符串)
nums=[‘张三‘,‘李四‘,‘王五‘,‘赵六‘]
print(nums[0])print(nums[1:3]) 顾头不顾尾,从第1个开始取,取到第3-1个为止print(nums[1:]) 如果从某个下标开始取,取到末尾结束,那么末尾的下标可以省略不写print(nums[:2]) 如果是从头开始取,取到后面某个下标结束,那么开头的下标可以不写print(nums[:]) 取所有的
lis = list(range(1,21))print(lis)print(lis[::2]) 步长,隔几个取一次print(lis[::-2]) 步长,隔几个取一次如果步长是正数的话,从左往右边开始取值如果步长是负数的话,从右边往左边开始取值print(lis[::-1]) #反转list 练习: #校验用户名是否合法:
# 输入账号 #input # 如果账号存在的,提示已经被注册,如果不存在的,就让他注册 all_users 【 】 #不能为空 #strip() #用户名长度长度6-12之间 len() #最多输入3次 #循环 all_users = [‘张三‘,‘李四‘,‘wifi‘]for i in range(3): username = input(‘请输入账号:‘).strip() if len(username)>5 and len(username)<13: if all_users.count(username)>0: print(‘这个名字太好啦,已经被注册啦!‘) else: print(‘名字不错,赶紧注册吧!‘) break else: print(‘用户名长度不合法!长度6-12之间!‘)else: print(‘失败次数过多‘)
2.字典 {key:value}键值对特点:1.取数据方便2.速度快3.字典是无序的4.如果直接循环一个字典的话,循环的是字典的keyinfo={‘name‘:‘fancy‘,‘sex‘:‘女‘,‘addr‘:‘地球‘}#查询:print(info.get(‘phone‘)) 取不到这个key的话,返回Noneprint(info.get(‘phone‘,110)) 取不到这个key的话,默认为110print(info[‘phone‘]) 若Key不存在时会报错 #增加:info[‘phone‘]=‘13600000000‘ 增加一个key,如果key存在的话,会修改原来key对的的valueinfo.setdefault(‘age‘:32) 增加一个key,如果key存在的话,不会修改原来key里面的value #修改:info[‘name‘]=‘lucy‘ #删除:info.pop(‘name‘) 删除指定key的键值对info.popitem() 随机删除一个keydel info[‘phone‘] 删除指定key的键值对info.clear() 清除字典#字典常用方法:print(info.values()) 获取到字典所有的valueprint(info.keys()) 获取到字典所有的keyprint(info.items()) 获取字典多有的键值对,k-v 注意:1.循环一个字典的话,循环的是字典的key,如:for p in people: print(p)2.循环的时候,同时取key和value:for k,v in people.items(): print(k,v) 练习:
users = { ‘Lucy‘:‘123456‘, ‘lili‘:‘456789‘,}#所有的账号和密码# username# pwd# cpwd# print( ‘123456‘ in users ) #字典里面用in来判断的话,只是判断key是否存在for i in range(3): username = input(‘账号:‘).strip() passwd = input(‘密码:‘).strip() cpasswd = input(‘密码确定:‘).strip() if username==‘‘ or passwd==‘‘ or cpasswd==‘‘: print(‘用户名/密码不能为空‘) elif username in users: print(‘用户名已经被注册!‘) elif passwd!=cpasswd: print(‘两次输入的密码不一致‘) else: print(‘恭喜,注册成功!‘) # users.setdefault(username,passwd) users[username]=passwd breakelse: print(‘错误次数过多‘)print(users)
3.元组:元组也是一个list,它和List的区别是元组里的元素无法修改同理,循环、切片,小标取值注:若元组里只有一个元素的话,必须在这个元素后加“,”,比如:t=(1,) print(t.index(2)) 找到元素的下标 print(t.count(2)) 找到元素的个数
4.常用的字符串方法:
# a=‘ 字 符 串 \n\n\n\n\n‘# c = a.strip() #默认去掉字符串两边的空格和换行符# c= a.lstrip() #默认去掉字符串左边的空格和换行符# c = a.rstrip() #默认去掉字符串右边的空格# print(‘c...‘,c)# print(‘a...‘,a) words = ‘http://www.baidu.com‘# print(words.strip(‘du‘)) #如果strip方法指定一个值的话,那么会去掉这两个值# print(words.count(‘a‘)) #统计字符串出现的次数#print(words.index(‘z‘)) #找下标,如果元素找不到的话,会报错# print(words.find(‘z‘)) #找下标,如果元素找不到的话,返回-1# print(words.replace(‘bai‘,‘BAI‘)) #替换字符串# print(words.isdigit()) #判断字符串是否为纯数字# print(words.startswith(‘http‘)) #判断是否以某个字符串开头# print(words.endswith(‘.jpg‘)) #判断是否以某个字符串结尾# print(words.upper()) #变成大写的# print(words.lower()) #变成小写的 username = ‘[email protected]#¥‘# print(username.isalpha()) #判断字符串是否全为字母# print(username.isalnum()) #判断是否包含字母和数字,它是只要有字母或者有数字就返回true
原文地址:https://www.cnblogs.com/fancyl/p/8658782.html
时间: 2024-08-11 03:28:51