python3--小数据池,is,字符编码
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)
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341