发布时间:2018-03-27 20:26:04编辑:Run阅读(3810)
is
a = 100
b = 100
print(a == b)
print(a is b)
执行输出
True
True
查看内存地址。使用id函数
>>> print(id(a))
1845124992
>>> print(id(b))
1845124992
内存地址一样
== 比较的是数值
is 比较的是内存地址
小数据池
只有数字和字符串类型
小数据池的作用就是节省内存
数字: -5--->256节省空间
这个范围指向的是同一内存地址
字符串
如果含有特殊字符,不存在小数据池
其它的数据类型,不存在小数据池
编码
asiic : 字母,数字,特殊字符;8位 1个字节表示1个字符。 unicode:万国码: Q :0000 0001 0000 0001 0000 0001 0000 0001 中:0000 0101 0000 0001 0000 0001 0000 0001 utf-8: a: 0000 0001 欧: 0000 0001 0000 0001 中: 0000 0001 0000 0001 0000 0001 gbk:国标 a: 0000 0001 中:0000 0001 0000 0001
编码之间的二进制互不识别
python3x中的编码:
python3x中的str在内存中的编码方式是unicode. python3x中的str不能直接存储和发送
bytes它的编码方式是非unicode(utf-8,gbk,gb2312)
对于英文:
str:表现形式:s = 'sam'
内部编码:unicode
bytes:表现形式:s = b'sam'
内部编码:非unicode
对于中文:
str: 表现形式: s = '中国'
内部编码:unicode
bytes: 表现形式: s1 = b'\xe4\xb8\xad\xe5\x9b\xbd'
内部编码: 非unicode
编码转换
字符串转换为bytes
s = '中国'
s1 = s.encode('utf-8')
print(s1)
执行输出
b'\xe4\xb8\xad\xe5\x9b\xbd'
一个\表示一位,上面的输出,可以看出占用了6位
s = 'sam'
s1 = s.encode('utf-8')
print(s1)
执行输出:
b'sam'
转换为gbk
s = 'hello girl'
s1 = s.encode('gbk')
print(s1)
执行输出:
b'hello girl'
只有将字符串写入文件或者发送数据时,才需要用到编码转换.
#!/usr/bin/env python # coding: utf-8 Python基础数据类型考试题 一,基础题。 1,简述变量命名规范(3分) 答: 变量名只能是字母,数字或者下划线的任意组合,变量名的第一个字母不能是数字,不能以关键字命名,变量的定义要有可描述性 2,字节和位的关系。(2分) 答 8位(bit)=1字节(Byte) 3,’太白’使用utf-8编码时,占的位数和字节数,是多少?使用gbk编码时,占的位数和字节数,是多少。(2分) 答 '太白'使用utf-8占 6字节 48位 gbk占用4字节,32位 4,默写字符串的十二个功能,并描述其作用。(12分) captalize 首字母大写 swapcase 大小写翻转 title每个单词的首字母大写 center 内容居中, count 字符串中元素出现的次数 startswith 以什么开头 endswith 以什么结尾 find 返回找到元素的索引,没有返回-1 index 返回找到元素的索引,找不到报错 split 以什么分割,形成一个列表 strip 去除左右两边的空格 replace 替换 isdigit 判断字符串是否由数字组成 5,数字,字符串,列表,元祖,字典对应的布尔值的False分别是什么?(5分) 数字, 0 字符串, '' 列表, [] 元组, () 字典, {} 6,书写Python2与python3中的三个不同。(3分) 1.print方法有区别 python 3x print('内容') python 2x print()或者print '内容' 2.编码方式不一样 python 3x 默认编码:utf-8 python 2x 默认编码: ascii 只包含英文字母和特殊字符以及数字 不支持中文 解决方式: 在头部增加 3.input不同 python 2x: raw_input() python 3x: input() 7,写代码,有如下列表,利用切片实现每一个功能(每题一分,共计4分) li = [1,3,2,'a',4,'b',5,'c'] 1)通过对li列表的切片形成新的列表l3,l3 = [’1,2,4,5] l3 = li[:7:2] 2)通过对li列表的切片形成新的列表l4,l4 = [3,’a’,’b’] l4 = li[1:6:2] 3)通过对li列表的切片形成新的列表l5,l5 = [‘c’] l5 = li[-1:-2:-1] 4)通过对li列表的切片形成新的列表l6,l6 = [‘b’,’a’,3] l6 = li[-3:-8:-2] 8,组合嵌套题。 a,写代码,有如下列表,按照要求实现每一个功能(每题3分,写出一种方法得1分,写出两种方法的3分。此题共9分) (每个都是一行代码实现) lis = [['k',['qwe',20,{'k1':['tt',3,'1']},89],'ab']] 1)将列表lis中的’tt’变成大写(用两种方式)。 lis[0][1][2]['k1'][0] = lis[0][1][2]['k1'][0].upper() lis[0][1][2]['k1'][0] = 'TT' 2)将列表中的数字3变成字符串’100’(用两种方式)。 lis[0][1][2]['k1'][1] = '100' lis[0][1][2]['k1'][1] = str(lis[0][1][2]['k1'][1] + 97) 3)将列表中的字符串’1’变成数字101(用两种方式)。 lis[0][1][2]['k1'][2] = 101 lis[0][1][2]['k1'][2] = int(lis[0][1][2]['k1'][2]+'01') b,写代码,有如下字典,按照要求实现每一个功能(5分) dic = {'k1':'v1','k2':['alex','sb'],(1,2,3,4,5):{'k3':['2',100,'wer']}} 1)将’k2’对应的值的最后面添加一个元素’23’。 dic['k2'].append('23') 2)将’k2’对应的值的第一个位置插入一个元素’a’。 dic['k2'].insert(0,'a') 3)将(1,2,3,4,5)对应的值添加一个键值对’k4’,’v4’。 dic[1,2,3,4,5]['k4'] = 'v4' 4)将(1,2,3,4,5)对应的值添加一个键值对(1,2,3),’ok’。 dic[1,2,3,4,5][(1,2,3)] = 'ok' 5)将’k3’对应的值的’wer’更改为’qq’。 dic[1,2,3,4,5]['k3'][2] = 'qq' 9,转化题(4分)。 Int与str之间如何转化,转换的结果是什么?有没有条件? int 转换为str 结果为str 没有条件限制 str 转换为int 结果为int 要求字符串必须由数字组成 Int 与 bool之间如何转化,转换的结果是什么?有没有条件? int --> bool 结果为bool 非0即True,0为False 没有条件限制 bool --> int 结果为int True为1,False为0 str 与 bool之间如何转化,转换的结果是什么?有没有条件? str --> bool 结果为true,没有条件限制 str 与 list 能否转化?如何转化? str 与 list 能否转化?如何转化? 能 str --> list 使用split()方法 list --> str 使用join()方法 10,实现下列结果(5分)。 li = ['alex','wusir','rain'] 1)有列表li = [‘alex’,’wusir’,’rain’]通过操作该列表构造一个字符串s=’alexwusirrain’ s = '' for i in li: s = s+i 2)有列表li = [‘alex’,’wusir’,’rain’]通过操作该列表构造一个字符串s=’alex*wusir*rain’ s = '' for i in li: s = s + '*' + i print(s) 3)有字符串s = ‘alexwusirlex’,通过操作该字符串构造一个列表li = [‘a’,’exwusirlex’] s = 'alexwusirlex' print(s.split('l', 1)) 4)有字符串s = ‘alex wusir’,通过操作该字符串构造一个列表li = [‘alex’,’wusir’] s = 'alex wusir' print(s.split(' ')) 5)有字符串s = ‘alex’通过操作该字符串构造一个字符串s1 = ‘a_l_e_x’ s = 'alex' print('_'.join(s)) 11,分别使用while循环,和for循环打印1-2+3-4+5.......+99的结果。(10分) num = 0 sum1 = 0 while num < 100: num += 1 if num % 2 == 1: sum1 -= num else: sum1 += num print(sum1) sum2 = 0 for i in range(1,100): if i % 2 == 1: sum2 += i else: sum2 -= i print(sum2) 12,使用range打印100,99,98,....1,0(2分) for i in reversed(range(0,101)): print(i) 13,计算用户输入内容中索引为奇数并且对应的元素为数字的个数(没有则个数为零)(6分) sum1 = 0 content = input('input:') for i in range(len(content)): if i % 2 == 1 and content[i].isdigit(): sum1 += 1 print(sum1) 14,补充代码(从已有的代码下面继续写):(6分) 有如下值li= [11,22,33,44,55,77,88,99,90],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。 li = [11,22,33,44,55,77,88,99,90] result = {} for row in li: li = [11, 22, 33, 44, 55, 77, 88, 99, 90] result = {} for row in li: if row > 66: if 'key1' not in result: result['key1'] = [] result['key1'].append(row) if row < 66: if 'key2' not in result: result['key2'] = [] result['key2'].append(row) print(result) 15,查找列表li中的元素,移除每个元素的空格,并找出以’A’或者’a’开头,并以’c’结尾的所有元素,并添加到一个新列表中,最后循环打印这个新列表。(3分) li = [‘taibai ’,’alexC’,’AbC ’,’egon’,’ Ritian’,’ Wusir’,’ aqc’] li = ['taibai ','alexC','AbC ','egon', 'Ritian',' Wusir',' aqc'] new_list = [] for i in li: i = i.strip() if (i.startswith('A') or i.startswith('a')) and i.endswith('c'): new_list.append(i) print(new_list) 16,实现一个整数加法计算器:(3分) 如:content = input(‘请输入内容:’) # 如用户输入:5+8+7....(最少输入两个数相加),然后进行分割再进行计算,将最后的计算结果添加到此字典中(替换None): dic={‘最终计算结果’:None}。 dic = {'最终计算结果':None} content = input('输入内容:').strip() s = content.split('+') sum1 = 0 for i in s: sum1 += int(i) dic['最终计算结果'] = sum1 print(dic) 17,按要求完成下列转化(如果按照索引去做,只能得4分)。(6分) list3 = [ {"name": "alex", "hobby": "抽烟"}, {"name": "alex", "hobby": "喝酒"}, {"name": "alex", "hobby": "烫头"}, {"name": "alex", "hobby": "Massage"}, {"name": "wusir", "hobby": "喊麦"}, {"name": "wusir", "hobby": "街舞"}, {"name": "太白", "hobby": "开车"}, ] # 如何把上面的列表转换成下方的列表? list4 = [ {"name": "alex", "hobby_list": ["抽烟", "喝酒", "烫头", "Massage"]}, {"name": "wusir", "hobby_list": ["喊麦", "街舞"]}, ] dic1 = {} for i in list3: if i['name'] not in dic1: dic1[i['name']] = {'name':i["name"],'hobby_list':[i['hobby']]} else: dic1[i['name']]['hobby_list'].append(i['hobby']) print(list(dic1.values())) 18,写程序:模拟公司hr录入员工账号密码的程序。(10分) 1),员工的账号密码存储在这种数据类型中: user_list = [ {'username':'barry','password':'1234'}, {'username':'alex','password':'asdf'}, ......... ] 2)非法字符模板:board = ['张三','李小四','王二麻子'] 3)Hr输入用户名,密码(可持续输入,如果想终止程序,那就在输入用户名时输入Q或者q退出程序),在Hr输入用户名时,检测此用户名是否有board里面的非法字符,如果有非法字符,则将非法字符替换成同数量的*(如王二麻子替换成****),然后添加到user_list中,如果没有非法字符,则直接添加到user_list中,每次添加成功后,打印出刚添加的用户名,密码。 board = ['张三','李小四','王二麻子'] user_list = [ {'username': 'barry','password':'1234'}, {'username': 'alex','password':'asdf'}, ] board = ['张三', '李小四', '王二麻子'] while True: username = input('输入用户名,密码(输入Q或者q退出)').strip() if username.upper() == 'Q': break password = input("输入密码:").strip() for x in board: if username in x: username = username.replace(x, '*'*len(x)) user_list.append({'username': username, 'password': password}) print("添加账号{},密码{}".format(username, password)) print(user_list)
上一篇: python3--字典,字典的嵌套,概念:分别赋值
下一篇: python3--尝试写一个三级菜单
47605
45985
36909
34469
29080
25713
24566
19714
19245
17756
5565°
6155°
5691°
5737°
6705°
5483°
5484°
5988°
5965°
7295°