Python全栈day10(基础知识练习题)

一,执行python的两种方式

  1,写在脚本里面调用python执行,例如python test.py

  2,  输入python在命令行交互执行,例如 python  >>> print 'Hello World'

 

二,简述位,字节的关系

  位(bit)来自英文bit,音译为“比特”,表示二进制位。位是计算机内部数据储存的最小单位

  字节(byte)字节来自英文Byte。字节是计算机中数据处理的基本单位。计算机中以字节为单位存储和解释信息,规定一个字节由八个二进制位构成,即1个字节等于8个比特(1Byte=8bit)。八位二进制数最小为00000000,最大为11111111;通常1个字节可以存入一个ASCII码,2个字节可以存放一个汉字国标码。

 

三,简述ascii,Unicode,utf-8,gbk的关系

  1.ASCII码

这是美国在19世纪60年代的时候为了建立英文字符和二进制的关系时制定的编码规范,它能表示128个字符,其中包括英文字符、阿拉伯数字、西文字符以及32个控制字符。它用一个字节来表示具体的字符,但它只用后7位来表示字符(2^7=128),最前面的一位统一规定为0

  2.Unicode符号集

正如上一节所说,世界上存在着多种编码方式,同一个二进制数字可以被解释成不同的符号。因此,要想打开一个文本文件,就必须知道它的编码方式,否则用错误的编码方式解读,就会出现乱码。为什么电子邮件常常出现乱码?就是因为发信人和收信人使用的编码方式不一样。而Unicode就是这样一种编码:它包含了世界上所有的符号,并且每一个符号都是独一无二的。比如,U+0639表示阿拉伯字母Ain,U+0041表示英语的大写字母A,U+4E25表示汉字“严”。具体的符号对应表,可以查询unicode.org,或者专门的汉字对应表 。很多人都说Unicode编码,但其实Unicode是一个符号集(世界上所有符号的符号集),而不是一种新的编码方式。

但是正因为Unicode包含了所有的字符,而有些国家的字符用一个字节便可以表示,而有些国家的字符要用多个字节才能表示出来。即产生了两个问题:第一,如果有两个字节的数据,那计算机怎么知道这两个字节是表示一个汉字呢?还是表示两个英文字母呢?第二,因为不同字符需要的存储长度不一样,那么如果Unicode规定用2个字节存储字符,那么英文字符存储时前面1个字节都是0,这就大大浪费了存储空间。

上面两个问题造成的结果是:1)出现了unicode的多种存储方式,也就是说有许多种不同的二进制格式,可以用来表示unicode。2)unicode在很长一段时间内无法推广,直到互联网的出现。

  3.UTF-8

互联网的普及,强烈要求出现一种统一的编码方式。UTF-8就是在互联网上使用最广的一种unicode的实现方式。其他实现方式还包括UTF-16和UTF-32,不过在互联网上基本不用。重复一遍,这里的关系是,UTF-8是Unicode的实现方式之一。

UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度。

UTF-8的编码规则很简单,只有两条:

1)对于单字节的符号,字节的第一位设为0,后面7位为这个符号的unicode码。因此对于英语字母,UTF-8编码和ASCII码是相同的。

2)对于n字节的符号(n>1),第一个字节的前n位都设为1,第n+1位设为0,后面字节的前两位一律设为10。剩下的没有提及的二进制位,全部为这个符号的unicode码。

  4.GBK/GB2312/GB18030

GBK和GB2312都是针对简体字的编码,只是GB2312只支持六千多个汉字的编码,而GBK支持1万多个汉字编码。而GB18030是用于繁体字的编码。汉字存储时都使用两个字节来储存。

  总结

ASCII编码:用来表示英文,它使用1个字节表示,其中第一位规定为0,其他7位存储数据,一共可以表示128个字符。

拓展ASCII编码:用于表示更多的欧洲文字,用8个位存储数据,一共可以表示256个字符

GBK/GB2312/GB18030:表示汉字。GBK/GB2312表示简体中文,GB18030表示繁体中文。

Unicode编码:包含世界上所有的字符,是一个字符集。

UTF-8:是Unicode字符的实现方式之一,它使用1-4个字符表示一个符号,根据不同的符号而变化字节长度。

 

四,请写出‘张三’分别用utf-8和gbk编码所占的位数

  utf-8一般使用三个字节代表一个汉字,占位为24位

  gbk使用两个字节代表一个汉字,占位为16位

 

五,Python单行注释和多行注释分别用什么

  单行注释使用# 多行注释使用''' '''或者""" """包含

 

六,声明变量的注意事项有哪些

  1,变量由大小写字母,数字及下划线组成并且开始不能为数字

  2,不能和python关键字重复

  3,不能使用系统函数作为变量名

 

七,如果有变量n1 = 5,请使用int提供的方法得到该变量最少可以用多少个二进制位表示。

  >>> int(5).bit_length()

  3

  3位

 

八,布尔值分别有什么

  True和False

 

九,阅读代码请写出执行结果

  capitalize方法是首字母大写

 a= 'zhangsan'
 b = a.capitalize()
print (a)
print (b)

zhangsan
Zhangsan

 

十,写代码有以下变量,请按要求实现以下功能

  name = ‘zhangsaN’

  a.移除变量name对应两边的空格并且输出移除后内容

v = name.strip()
print(v)

zhangsaN

  b.判定变量name是否以‘zh‘’开头,并且输出结果

name = 'zhangsaN'
v = name.startswith('zh')
print(v)

True

  c.判定变量name是否以‘N’结尾,并且输出结果

name = 'zhangsaN'
v = name.endswith('N')
print(v)

True

  d.将h替换为p并输出结果

name = 'zhangsaN'
v = name.replace('h','p')
print(v)

zpangsaN

  e.将变量以h分割并输出结果

name = 'zhangsaN'
v = name.split('h')
print(v)

['z', 'angsaN']

  f.上一题以h分割后得到的是什么类型

  list 列表

  g.name变量变大写,输出结果

name = 'zhangsaN'
v = name.upper()
print(v)

ZHANGSAN

  h.name变量变小写,输出结果

name = 'zhangsaN'
v = name.lower()
print(v)

zhangsan

  i.输出变量name的第二个字符

name = 'zhangsaN'

print(name[1])

h

  j.输出变量name前三个字符

name = 'zhangsaN'

print(name[0:3])

zha

  k.输出变量name后两个字符

name = 'zhangsaN'

print(name[-2:])

aN

  l.输出变量name中h所在是索引位置

name = 'zhangsaN'

v = name.find('h')

print(v)

1

  m.输出子序列不包括最后一个字符

name = 'zhangsaN'

v = name[0:-1]

print(v)

zhangsa

 

十一,字符串是否可迭代对象,请使用循环输出每一个元素

  字符串可以迭代,能被for循环进行循环的就是可迭代对象

name = 'zhangsaN'
for item in name:
    print(item)

 

十二,请用代码实现

  a,利用下划线将每一个元素拼接为字符串li = ‘zhangsan’

  b,利用下划线将每一个元素拼接为字符串li = ['zhangsan','lisi','wangwu']

li = "zhangsan"
v = '_'.join(li)
print(v)

z_h_a_n_g_s_a_n

  

li = ['zhansan','lisi','wangwu']
v = '_'.join(li)
print(v)

zhansan_lisi_wangwu

  

十三,python2和python3中函数range的区别

  python2中的range返回的是一个列表,xrange和python3里面的range效果是一样的

  python3中的range返回的是一个迭代值

  

十四,实现一个整数加法运算

  如:content=(‘请输入内容例如5+9:’)

content=input('Please input')
v = content.split('+')
n1 = v[0]
n2 = v[1]
print(int(n1)+int(n2))

 

十五,计算用户输入的有多少个数字,多少个字母

content=input('Please input')
letter_count = 0
number_count = 0
for item in content:
    if item.isalpha():
        letter_count = letter_count + 1
    elif item.isdigit():
        number_count = number_count + 1

print('字母数为:',letter_count)
print('数字数为:',number_count)

  通过迭代循环判断是否为数字或字母如果为数字或者字母则+1迭代玩输出结果

 

十六,制作趣味模板程序根据用户输入姓名,地点,爱好输出 亲爱的xxx喜欢在xxx做xxx

name = input('请输入姓名:')
add = input('请输入地点:')
thing = input('请输入你喜欢做的事情:')
print(name,'喜欢在',add,thing)

  

十七,制作随机验证码,不区分大小写


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)
v = input('>>>')
if v.upper() == code:
print('You input is right')
else:
continue
 

 

十八,开发敏感词过滤如果内容包含敏感字符则替换为***

v = input('>>>')
v = v.replace('1','a')
v = v.replace('2','b')
print(v)

 

 

  

  

 

  

    

posted @ 2017-12-25 15:40  minseo  阅读(390)  评论(0编辑  收藏  举报