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)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程

Python中的数字

写Python文件“使用说明”: Python的文件当然要以.py为结尾。 Linux上编写python文件要声明编译器位置: 首行:#!/usr/bin/py...

2288
来自专栏容器云生态

awk-grep-sed简单使用总结(正则表达式的应用)

正则表达式: 匹配一组字符: #[ns]a.\.xls  //[]用于限定字符;“.”用于匹配任意字符; \.用于转义"." 匹配到s/na*.xls  [n...

2579
来自专栏CVer

排序算法 | 冒泡排序(含C++/Python代码实现)

排序算法,就是如何使得记录按照要求排列的方法。排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面。排序算法有很多,本文将介绍最经典的排序算法:冒泡排序...

1182
来自专栏Pythonista

python内建函数

abs()函数返回数字(可为普通型、长整型或浮点型)的绝对值。如果给出复数,返回值就是该复数的模。例如:

1531
来自专栏猿人谷

不用加减乘除做加法

题目:写一个函数,求两个整数之和,要求在函数体内不得使用+、-、×、÷四则运算符号。 分析: 第一步:不考虑进位对每一位相加。0加0、1加1的结果都是0,0加1...

2167
来自专栏炉边夜话

java 异常处理学习笔记

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

942
来自专栏代码世界

Python基础数据类型之集合以及其他和深浅copy

一、基础数据类型汇总补充 list  在循环一个列表时,最好不要删除列表中的元素,这样会使索引发生改变,从而报错(可以从后向前循环删除,这样不会改变未删元素的索...

3069
来自专栏Python

Python常见数据结构整理 Python常见数据结构整理

Python常见数据结构整理 Python中常见的数据结构可以统称为容器(container)。序列(如列表和元组)、映射(如字典)以及集合(set)是三类主要...

1937
来自专栏决胜机器学习

《Redis设计与实现》读书笔记(六) ——Redis中的压缩列表

《Redis设计与实现》读书笔记(六) ——Redis中的压缩列表 (原创内容,转载请注明来源,谢谢) 一、概述 压缩列表(ziplist)是列表键(list)...

3897
来自专栏null的专栏

挑战数据结构与算法面试题——统计上排数在下排出现的次数

题目来源“数据结构与算法面试题80道”。在此给出我的解法,如你有更好的解法,欢迎留言。 ? 分析: 本题应该是一个确定的问题,即上排的是个数是题目中给定的...

3206

扫码关注云+社区

领取腾讯云代金券