我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python3--小数据池,is,字符编码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

blob.png

编码转换

字符串转换为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

python3--小数据池,is,字符编码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python3--小数据池,is,字符编码

isa = 100b = 100print(a == b)print(a is b)执行输出TrueTrue查看内存地址。使用id函数>>> print(id(a))1845124992>>> print(id(b))1845124992内
2023-01-30

mysql如何查看数据库字符编码

要查看数据库的字符编码,可以使用以下命令:SHOW CREATE DATABASE database_name;在上面的命令中,将 database_name 替换为要查看的数据库的名称。执行这个命令后,将会显示出数据库的创建语句,其中包
mysql如何查看数据库字符编码
2024-04-09

mysql数据库的字符编码怎么修改

mysql数据库字符编码可通过以下方法修改:修改数据库字符编码:alter database database_name character set new_character_set;修改表字符编码:alter table table_n
mysql数据库的字符编码怎么修改
2024-05-22

mysql数据库默认字符编码是什么

默认字符编码取决于操作系统:unix/linux:utf8mb4windows:mysql 8.0+:utf8mb4,mysql 5.7-:latin1MySQL 数据库默认字符编码MySQL 数据库的默认字符编码取决于操作系统和安装配置
mysql数据库默认字符编码是什么
2024-04-22

数据类型及字符编码 (需要重新修改)

1.数据类型:  数字(整型,长整型,浮点型,复数)  字符串:在介绍字符编码时介绍字节bytes类型  列表  元祖  字典  集合2.整型 int  作用:年级/等级/身份证号等整型数字相关  定义: age=10  本质上age=in
2023-01-30

PostgreSQL数据库字符串拼接、大小写转换及substring代码分析

今天小编给大家分享一下PostgreSQL数据库字符串拼接、大小写转换及substring代码分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我
2023-07-06

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录