1、执行 Python 脚本的两种方式

脚本:脚本简单地说就是一条条的文字命令,这些文字命令是可以看到的(如可以用记事本打开查看、编辑),脚本程序在执行时,是由系统的一个解释器,将其一条条的翻译成机器可识别的指令,并按程序顺序执行。因为脚本在执行时多了一道翻译的过程,所以它比二进制程序执行效率要稍低一些。

关于编译器与解释器的区别:https://blog.csdn.net/touzani/article/details/1625760

从Hello World 谈Python运行原理:https://blog.csdn.net/sxb0841901116/article/details/21418885

 

2、简述位、字节的关系
  

      位:"位(bit)"是电子计算机中最小的数据单位。每一位的状态只能是0或1。

  字节:8个二进制位构成1个"字节(Byte)",它是存储空间的基本计量单位。1个字节可以储存1个英文字母或者半个汉字,换句话说,1个汉字占据2个字节的存储空间。

  简单的说
  字(word) 占2字节
  字节(byte) 占8位
  位(bit) 最小的单位
  比特就是 bit ,就是位。
  1字=2字节
  1字节=8位
  1字=2*8=16位

3、简述 a sc ii、 u n i c o de、 u t f-8、 gbk 的关系
ASCII:(American Standard Code for Information Interchange,美国信息交换标准代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言。它是现今最通用的单字节编码系统,并等同于国际标准ISO/IEC 646。

Unicode:(统一码、万国码、单一码)是计算机科学领域里的一项业界标准,包括字符集、编码方案等。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。

UTF-8:(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。由Ken Thompson于1992年创建。现在已经标准化为RFC 3629。UTF-8用1到6个字节编码Unicode字符。用在网页上可以统一页面显示中文简体繁体及其它语言(如英文,日文,韩文)。

GBK :是又一个汉字编码标准,全称《汉字内码扩展规范》(GBK),英文名称 Chinese Internal Code Specification ,中华人民共和国全国信息技术标准化技术委员会 1995 年 12 月 1 日制订,国家技术监督局标准化司、电子工业部科技与质量监督司 1995 年 12 月 15 日联合以技监标函 [1995] 229 号文件的形式,将它确定为技术规范指导性文件,发布和实施。这一版的 GBK 规范为 1.0 版。GB 即“国标”,K 是“扩展”的汉语拼音第一个字母。 

    a.Unicode 和 UTF-8 有何区别:

                https://www.zhihu.com/question/23374078

    b.GBK和UTF-8是什么,它们有什么区别:

 GBK包含中日韩字符集合,他能完美支持简体中文和英文,但如果在IE没有安装简体中文支持的电脑上阅读GBK编码的网页,中文会变成乱码,例  如英国人浏览您的网站,电脑全是火星文,UTF-8则包含了大部分文字的编码,可以表达更多的语言,使用UTF-8一个最大的好处就是其他地区的用 户(美国、印度、台湾)无需安装简体中文支持,就能正常看您的文字,并且不会出现乱码,通常网络传输也是使用UTF-8编码。

 

  • unicode:包含所有国家的字符编码,
  • utf-8可变长的字符编码,英文表示一个字节,中文(繁文)表示3个字节
  • ascii美国标志信息交换代码,是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,一个字符占一个字节
  • gbk全称《汉字内码扩展规范》,一个字符占用两个字节

 

4、请写出 “李杰” 分别用 utf-8 和 gbk 编码所占的位数

  • 在utf-8中,一个中文字符占用3个字节
  • 在gbk中一个汉字占用2个字节
  • 李杰 = utf-8(6字节)=48
  • 李杰 = gbk(4字节)=32

 

5、Pyhton 单行注释和多行注释分别用什么?

  • 单行注释 #被注释内容 井号(#)常被用作单行注释符号,在代码中使用#时,它右边的任何数据都会被忽略,当做是注释。
    print 1 #输出1
    #号右边的内容在执行的时候是不会被输出的。

 

  • 多行注释 '''被注释内容'''多行注释是用三引号'''   '''包含的。

 

6、声明变量注意事项有那些?


声明变量:简单的说就是避免编程时产生不必要的错误,一位不同类型变量的存储格式和长度都不同,所以字节长度不同,声明变量可以让计算机知道你更需要用什么样的格式存储变量,从而高效稳定地运行程序。
  • 变量名只能是 字母、数字或下划线的任意组合
  • 变量名的第一个字符不能是数字
  • 以下关键字不能声明为变量名
  • ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']
  • 最好不好和python内置的东西重复

 

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

 

n1=5
v = int(n1.bit_length())
print(v)

执行结果:

3

 

8.布尔值分别有什么?

  • 一个布尔值只有True、False两种值,要么是True,要么是False
  • 可以用0或1表示

 

 a    =    "alex"     
 b    =    a.capitalize()     
print(a)     
print(b)     

执行结果:

 alex
 Alex

 

 

10、写代码,有如下变量,请按照要求实现每个功能  

name="aleX"

a.移除 name 变量对应的值两边的空格,并输入移除后的内容
print(name.strip()) #aleX

b.判断 name 变量对应的值是否以"al"开头,并输出结果
print(name.startswith('al')) #False

c.判断 name 变量对应的值是否以"X"结尾,并输出结果
print(name.endswith('X')) #False

d.将 name 变量对应的值中的“l”替换为“p”,并输出结果
print(name.replace('l','p')) #aleX

e.将 name 变量对应的值根据“l”分割,并输出结果。
print(name.split('l')) #['a', 'eX']

f.请问,上一题e分割之后得到值是什么类型(可选)
print(type(name.split('l'))) #<class 'list'>

g.将 name 变量对应的值变大写,并输出结果
print(name.upper()) #ALEX

h.将 name 变量对应的值变小写,并输出结果
print(name.lower()) #alex

i.请输出 name 变量对应的值的第 2 个字符?
print(name[1:2]) #l

j.请输出 name 变量对应的值的前 3 个字符?
print(name[:3]) #ale

k.请输出 name 变量对应的值的后 2 个字符?
print(name[-2:]) #eX

l.请输出 name 变量对应的值中“e”所在索引位置?
print(name.index('e')) #2

m.获取子序列,仅不包含后一个字符。如:oldboy则获取oldbo;root则获取roo

字符?

 

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-      
3 #Author: nulige
4 
5 n1 = "oldboy"
6 n2 = n1.strip('y')
7 print(n2)

执行结果:

1 oldbo

21、字符串是否可迭代对象?如可以请使用for 循环每一个元素?

python循环语句:http://www.runoob.com/python/python-loops.html 

可以

1 name = "nulige"
2 for i in name:
3     print(i)

执行结果:

1 n
2 u
3 l
4 i
5 g
6 e

补充知识:

什么是迭代?

 

利用 for 循环来遍历一个列表(list)或元组(tuple),将值依次取出,这种方法我们称为迭代。

 利用for语句迭代字符串,创建一个字符串,name = "nulige",然后用for语句进行迭代。

 

22、请用代码实现:

a. 利用下划线将列表的每一个元素拼接成字符串, li = "alexericrain"

1 li = "alexericrain"
2 v = "_".join(li)
3 print(v)

执行结果:

1 a_l_e_x_e_r_i_c_r_a_i_n

 

b. 利用下划线将列表的每一个元素拼接成字符串, li = ['alex', 'eric', 'rain'] (可选)

1 li = ['alex','eric','rain']
2 v = "_".join(li)
3 print(v)

执行结果:

1 alex_eric_rain

 

23、 Python2 中的 range 和 Python3 中的 range 的区别?

python2直接就在内存中创建出来

pyhotn3没有在内存中创建出来,需要使用for循环才会创建出来

 

24、实现一个整数加法计算器:
如:content=input('请输入内容:')#如:5+9或5+9或5+9

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #Author: nulige
4 
5 n1 = int(input("name:"))
6 n2 = int(input("age:"))
7 info = n1+n2
8 print(info)

 

执行结果:

1 name:5
2 age:9
3 14

 

25、计算用户输入的内容中有几个十进制小数?几个字母?

如: content = input('请输入内容: ') # 如: asduiaf878123jkjsfd-213928

 

1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 #Author: nulige
 4 
 5 number_null = ""
 6 name = "123456asdfsdf"
 7 str_null = ""
 8 for i in name:
 9     if i.isdecimal():  #判断i的值是不是数字
10         number_null += i #如果i的值是数字的话,则加入到number_null
11     elif  i.isalpha():  #判断i的值是不是字母
12             str_null += i   
13 print(number_null,str_null)
14 print(len(number_null),len(str_null))

执行结果:

1 123456 asdfsdf
2 6 7

为什么python中,程序开始都要敲入“# -*- coding: UTF-8 -*-” 这个有什么作用呢:PY文件当中是不支持中文的,即使你输入的注释是中文也不行,为了解决这个问题,就需要把文件编码类型改为UTF-8的类型,输入这个代码就可以让PY源文件里面有中文了。建议你写代码之前都把这句话加上,因为不管是注释还是弹出消息提示,免不了的要输入中文,所以这个基本是必须的。

 

26、简述 int 和 9 等数字 以及 str 和 "xxoo" 等字符串的关系?
 数字就是整型,带“ ”的就是字符串

 

27、制作趣味模板程序

需求:等待用户输入名字、地点、爱好,根据用户的名字和爱好进行任意现实

如:敬爱可亲的 xxx,喜欢在 xxx 地方干 xxx

 

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-      
3 #Author: nulige
4  
5 n1 = input("name:")
6 n2 = input("add:")
7 n3 = input("hobby:")
8 print("敬爱的",n1,"喜欢在",n2,"安静的",n3)

执行结果:

1 name:成龙
2 add:图书馆
3 hobby:看书
4 敬爱的 成龙 喜欢在 图书馆 安静的 看书

 

28、制作随机验证码,不区分大小写。

流程: - 用户执行程序

   - 给用户显示需要输入的验证码

   - 用户输入的值

        用户输入的值和显示的值相同时现实正确信息;

                  否则继续生成随机验证码继续等待用户输入

   生成随机验证码代码示例:

 

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-      
 3 #Author: nulige
 4 
 5 def check_code():
 6     import random
 7     checkcode = ''
 8     for i in range(4):
 9         current = random.randrange(0,4)
10         if current != i:
11             temp = chr(random.randint(65,90))
12         else:
13             temp = random.randint(0,9)
14         checkcode += str(temp)
15     return checkcode
16 code = check_code()
17 print(code)
18 
19 count = 0
20 while count < 3:
21     identifying_code = input("请输入验证码:")
22     if code ==  identifying_code.upper():
23         print("验证通过---登录成功---")
24         break
25     else:
26         continue
27     count += 1

执行结果:

1 请输入验证码:lwv9
2 验证通过---登录成功---

 29、开发敏感词语过滤程序,提示用户输入内容,如果用户输入的内容中包含特殊的字符:
如:"苍老师"“东京热”,则将内容替换为***

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-      
3 #Author: nulige
4 
5 n1 = input("请输入:")
6 m = str.maketrans("苍老师", "***")
7 a = str.maketrans("东京热", "***")
8 new_v = n1.translate(m).translate(a)
9 print(new_v)

执行结果:

1 请输入:苍老师
2 ***

30、制作表格

循环提示用户输入:用户名、密码、邮箱  (要求用户输入的长度不超过 20 个字符,如果超过则只有前 20 个字符有效) 如果用户输入  q 或 Q  表示不再继续输入,将用户输入的内容以表格形式打印

 1 W = "用户名\t密码\t邮箱\n"
 2  while 1 == 1:
 3      name = input("asfdsa:")
 4      if name == "q" or name == "Q" or name == "no":
 5          print(w)
 6          break
 7      passwd = input("密码:")
 8      if passwd == "q" or passwd == "Q" or quit == "no":
 9          print(w)
10          break
11      mail = input("邮箱:")
12      if mail == "q" or mail == "Q" or mail == "no":
13          print(w)
14          break
15      Name = name[0:20]
16      Pwd = passwd[0:20]
17      Mail = mail[0:20]
18      b = "{0}\t{1}\t{2}\n".format(Name,Pwd,Mail)
19      n1 = W + b
20      w = n1.expandtabs(20)
21      continue

 

执行结果:

1 用户名:asfdsa
2 密码:ddd
3 邮箱:qq@qq.com
4 用户名:q
5 用户名                 密码                  邮箱
6 asfdsa              ddd                 qq@qq.com

 

posted on 2018-03-30 20:10  c富-  阅读(325)  评论(0编辑  收藏  举报