第2章 Python基础-字符编码&数据类型 字符编码&字符串 练习题
1.简述位、字节的关系
位(bit)是计算机中最小的表示单元,数据传输是以“位”为单位的,1bit缩写为1b
字节(Byte)是计算机中最小的存储单位,1Byte缩写为1B
8bit = 1Byte
2.简述ascii、unicode、uft-8、gbk的关系
美国制定了一套字符编码,对英语字符与二进制位之间的关系做了统一规定,这被称为ASCII码,由1个字节组成,最多支持2**8=256个字符
Unicode是国际组织制定的可以容纳世界上所有文字和符号的字符编码方案,现代操作系统和大多数编程语言都直接支持Unicode,不管是英文字母还是汉字,通常由2个字节组成(只有很生僻的字符才会被编码成4个字节),最多支持2**16=65536个字符,如果文本基本全部都是英文的话,用Unicode编码比ASCII编码需要多一倍的存储空间,所以本着节约精神,出现了UTF-8编码
UTF-8最大的特点就是它是一种可变长的编码方式,通常由1-3个字节组成,常用的英文字母被编码成1个字节,汉字通常是3个字节(只有很生僻的字符才会被编码成4-6个字节),同时ASCII编码可以看成UTF-8编码的一部分(英文字符),所以只支持ASCII编码的软件可以在UTF-8编码下运行
GBK是汉字国标扩展码,由于GBK同时也涵盖了Unicode所有CJK汉字,所以也可以和Unicode做一一对应。Windows默认编码GBK,中文占2个字节
现在计算机系统通用的字符编码工作方式:在计算机内存中,统一使用Unicode编码,当需要保存到硬盘或需要传输时候,就转换为UTF-8编码
3.请写出“李杰”分别用utf-8和gbk编码所占的位数
UTF-8中一个英文占1个字节,一个中文占3个字节,此处“李杰”占6个字节
GBK中一个中文占2个字节,此处“李杰”占4个字符
4.如有一个变量n1 = 5,请使用int提供的方法,得到该变量最少可以用多少个二进制位表示?
#!/usr/bin/env python
#-*- encoding:utf-8 -*- n1 = 5
v = int.bit_length(n1)
print(v)
5.布尔值分别有什么?
True和False
"" [] () {} => False #空字符串,空列表,空元祖,空字典
"有内容" => True
0 => False
其他数字 => True
6.阅读代码,请写出执行结果
a = "alex"
b = a.capitalize()
print(a)
print(b)
执行结果:
alex
Alex
#首字母变大写,其他字母变小写
7.写代码,有如下变量,请按照要求实现每个功能
name=" aleX"
a.移除name变量对应的值两边的空格,并输出移除后的内容
print(name.strip())
b.判断name变量对应的值是否以"al"开头,并输出结果
print(name.startswith('al'),name)
c.判断name变量对应的值是否以"X"结尾,并输出结果
print(name.endswith('X'),name)
d.将name变量对应的值中的"l"替换为"p",并输出结果
print(name.replace('l','p'))
e.将name变量对应的值中的"l"分割,并输出结果。
print(name.split('l'))
f.请问,上一题l分割之后得到是什么类型(可选)?
#列表
g.将name变量对应的值变大写,并输出结果
print(name.upper())
h.将name变量对应的值变小写,并输出结果
print(name.lower())
i.请输出name变量对应的值的第2个字符?
print(name[1])
j.请输出name变量对应的值的前3个字符?
print(name[:3])
k.请输出name变量对应的值的后2个字符?
print(name[-2:]) #-1代表最后一个字符,-2代表倒数第二个字符
l.请输出name变量对应的值中"e"所在的索引位置?
print(name.index('e'))
m.获取子序列,仅不包含最后一个字符。如:oldboy 则获取oldbo;root则获取roo
print(name.rstrip(name[-1:]))
8.字符串是否可迭代?如可以请使用 for 循环每一个元素?
#可迭代对象==可以被for进行循环获取
name = "aleX"
for i in name:
print(i)
9.请用代码实现:
a.利用下划线将列表的每一个元素拼接成字符串,li = "alexericrain"
li = "alexericrain"
print('_'.join(li))
b.利用下划线将列表的每一个元素拼接成字符串,li = ['alex','eric','rain']
li = ['alex','eric','rain']
print('_'.join(li))
10.Python2中的range和Python3中的range的区别?
Python2中的range返回的是一个列表,直接创建内容
Python3中的range返回的是一个迭代值,只有for循环时,内容才一个一个创建
11.实现一个整数加法计算器:
如:
content = input('请输入内容:') #如:5+9
#方法一:
content = input('请输入内容:')
print(eval(content)) #方法二:
content = input('请输入内容:') #5+9
n1,n2 = content.split('+')
n1 = int(n1)
n2 = int(n2)
print(n1+n2)
12.计算用户输入的内容中有几个十进制数?几个字母?
如:
content=input('请输入内容:') #如: asduiaf878123jkjsfd-213928
content = input('请输入内容:')
number_of_decimal = 0
number_of_alpha = 0
for i in content:
if i.isdecimal():
number_of_decimal += 1
if i.isalpha():
number_of_alpha += 1
print('十进制数的数量:', number_of_decimal, '字母的数量:', number_of_alpha)
content=input('请输入内容:')
number_of_decimal = 0
number_of_alpha = 0
for i in range(len(content)):
if content[i].isdecimal():
number_of_decimal += 1
if content[i].isalpha():
number_of_alpha += 1
print('十进制数的数量:',number_of_decimal,'字母的数量:',number_of_alpha)
13.简述int和9等数字以及str和"xxoo"等字符串的关系?
int,str 是类
0和"xxoo"是根据相应的类创建的对象
14.制作随机验证码,不区分大小写。
流程:
- 用户执行程序
- 给用户显示需要输入的验证码
- 用户输入的值
用户输入的值和显示的值相同时显示正确信息;否则继续生成随机验证码继续等待用户输入
生成随机验证码事例:
def check_code():
import random
checkcode = ''
for i in range(4):
current = random.randrange(0,4)
if current != i:
temp = chr(random.randint(65,90))
else:
temp = random.randint(0,9)
checkcode += str(temp)
return checkcode code = check_code()
print(code)
#!/usr/bin/env python
# -*- encoding: utf8 -*- def check_code():
import random
checkcode = ''
for i in range(4):
current = random.randrange(0, 4)
if current != i:
temp = chr(random.randint(65, 90))
else:
temp = random.randint(0, 9)
checkcode += str(temp)
return checkcode while True:
code = check_code()
print(code)
app = input("请输入验证码:")
if code.upper() == app.upper():
print("输入正确")
break
else:
print("输入错误")
s = input("是否重新输入?")
if s == "no":
break
else:
continue
15.开发敏感词语过滤程序,提示用户输入内容,如果用户输入的内容中包含特殊的字符:
如“苍老师”“东京热”,则将内容替换为***
v = input(">>>")
v = v.replace("苍老师","***")
v = v.replace("东京热","***")
print(v)
16.制作表格
循环提示用户输入:用户名、密码、邮箱(要求用户输入的长度不超过20个字符,如果超过则只有前20个字符有效)
如果用户输入q或Q表示不再继续输入,将用户输入的内容以表格形式显示。
#!/usr/bin/env python
# -*- encoding: utf8 -*- s = ""
while True:
name = input("用户名:")
if name == "q" or name == "Q":
break
if len(name) >= 20:
name = name[:20]
passwd = input("密码:")
if len(passwd) >= 20:
passwd = passwd[:20]
email = input("邮箱:")
if len(email) >= 20:
email = email[:20]
template = "{0}\t{1}\t{2}\n"
v = template.format(name, passwd, email)
s += v print(s.expandtabs(20))
第2章 Python基础-字符编码&数据类型 字符编码&字符串 练习题的更多相关文章
- Python基础4:数据类型:数字 字符串 日期
[ Python 数据类型 ] 我们知道,几乎任何编程语言都具有数据类型:常见的数据类型有:字符串.整型.浮点型以及布尔类型等. Python也不例外,也有自己的数据类型,主要有以下几种: 1.数字: ...
- [Python笔记][第一章Python基础]
2016/1/27学习内容 第一章 Python基础 Python内置函数 见Python内置函数.md del命令 显式删除操作,列表中也可以使用. 基本输入输出 input() 读入进来永远是字符 ...
- 0003.5-20180422-自动化第四章-python基础学习笔记--脚本
0003.5-20180422-自动化第四章-python基础学习笔记--脚本 1-shopping """ v = [ {"name": " ...
- Python基础篇(格式化输出,运算符,编码):
Python基础篇(格式化输出,运算符,编码): 格式化输出: 格式:print ( " 内容%s" %(变量)) 字符类型: %s 替换字符串 %d 替换整体数字 ...
- python基础之序列类型的方法——字符串方法
python基础之序列类型的方法--字符串方法 Hello大家好,我是python学习者小杨同学,经过一段时间的沉淀(其实是偷懒不想更新),我终于想起了自己的博客账号,所以这次带来的是序列方法的后半部 ...
- 第1章 Python基础之字符编码
阅读目录 一.什么是字符编码 二.字符编码分类 三.字符编码转换关系 3.1 程序运行原理 3.2 终极揭秘 3.3 补充 总结 回到顶部 一.什么是字符编码 计算机要想工作必须通电,也就是说'电'驱 ...
- python基础(8):基本数据类型三(dict)、is和==、编码和解码
1. 字典 1.1 字典的介绍 字典(dict)是python中唯一的一个映射数据类型,它是以{}括起来的键值对组成.在dict中key是唯一的,在保存的时候,根据key来计算出一个内存地址,然后将k ...
- python基础(三)----字符编码以及文件处理
字符编码与文件处理 一.字符编码 由字符翻译成二进制数字的过程 字符--------(翻译过程)------->数字 这个过程实际就是一个字符如何对应一个特定数字的标准,这个标准称之 ...
- python基础知识(七)---数据类型补充、"雷区"、编码
数据类型补充."雷区".编码 1.数据类型补充 str: #字符串数据类型补充 s1=str(123) #常用于类型转换 print(s1) #capitalize()首字母大写 ...
随机推荐
- docker安装tomcat
先在官网上找可用的镜像 我使用的是7-jre8 获取tomcat镜像的命令:$docker pull tomcat:7-jre8 获取完镜像以后,通过命令可以列举出已有的镜像: 列举镜像的命令:$do ...
- 报错信息:The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path
用Eclipse创建jsp页面时,提示这个错误 解决的方法是:右键项目,Build Path->Configure Build Path Add Library Server Runtime,这 ...
- 使用angular5+ionic3+sqlite创建离线app应用
1.安装sqlite和toast插件 npm install --save @ionic-native/sqlite npm install --save @ionic-native/toast 未完 ...
- MySQL 存储过程/游标/事务
将会用到的几个表 mysql> DESC products; +------------+--------------+------+-----+---------+-------------- ...
- common.js 2017
String.IsNullOrEmpty = function (v) { return !(typeof (v) === "string" && v.length ...
- 微软BI 之SSRS 系列 - 如何实现报表标签的本地化 - 中文和英文的互换
SSRS 中并没有直接提供本地化的配置方式,因此在 SSRS 中实现本地化,比如有英文标题还有可选的中文标题,就需要通过其它的方式来解决. 比如默认是这样的英文标题 - 但是本地中方用户可能比较喜欢看 ...
- Zoning and LUN Masking
In a SAN ( Storage Area Network ), if all the hosts are allowed to access all the drives in the SAN, ...
- MAC LINUX 安装PYQT(事例)
MAC安装 1.安装命令:brew install pyqt Warning: Your Xcode () is outdated Please install Xcode 5.0. Warning: ...
- MongoDB numa系列问题三:overcommit_memory和zone_reclaim_mode
内核参数overcommit_memory : 它是 内存分配策略 可选值:0.1.2.0:表示内核将检查是否有足够的可用内存供应用进程使用:如果有足够的可用内存,内存申请允许:否则,内存申请失败,并 ...
- SSM实战——秒杀系统之高并发优化
一:高并发点 高并发出现在秒杀详情页,主要可能出现高并发问题的地方有:秒杀地址暴露.执行秒杀操作. 二:静态资源访问(页面)优化——CDN CDN,内容分发网络.我们把静态的资源(html/css/j ...