1、? 执行 Python 脚本的两种方式
交互方式:命令行
Windows操作系统下,快捷键cmd,输入“python”启动交互式python解释器。
文件方式:python文件
2、? 简述位、字节的关系
一个二进制位是计算机里最小表示单元。
一个字节是计算机里最小存储单元。
二进制位=8bits=1Byte=1字节
3、? 简述 ascii、unicode、utf-8、gbk 的关系
美国制定了一套字符编码,对英语字符与二进制位之间的关系,做了统一规定。这被称为ASCII码。
Unicode是国际组织制定的可以容纳世界上所有文字和符号的字符编码方案。将世界上所有的符号都纳入其中。每一个符号都给予一个独一无二的编码,那么乱码问题就会消失。这就是Unicode,就像它的名字都表示的,这是一种所有符号的编码。
互联网的普及,强烈要求出现一种统一的编码方式。UTF-8就是在互联网上使用最广的一种Unicode的实现方式。UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度。UTF-8中,英文占一个字节,中文占3个字节。
GBK: 汉字国标扩展码,基本上采用了原来GB2312-80所有的汉字及码位,并涵盖了原Unicode中所有的汉字20902,总共收录了883个符号, 21003个汉字及提供了1894个造字码位。由于GBK同时也涵盖了Unicode所有CJK汉字,所以也可以和Unicode做一一对应。windows默认编码GBK,中文占2个字节。
4、? 请写出 ?“李杰” ?分别用 utf-?8 和 gbk 编码所占的位数
utf-8中,一个英文占一个字节,一个中文占3个字节,此处“李杰”占6个字节。
GBK中一个中文占2个自己,此处“李杰”占4个字符。
5、? Pyhton 单行注释和多行注释分别用什么?
python单行注释用#,多行注释用三引号“‘ ? ?’”。
6、? 声明变量注意事项有那些?
声明变量需先赋值。变量名可以包含字母、数字和下划线_。变量不能以数字开头。
7、如何查看变量在内存中的地址?
id(变量名) ?#查看内存地址。
8、执行 Python 程序时,自动生成的 ?.pyc ?文件的作用是什么?
Python这样保存字节码是作为一种启动速度的优化。下一次运行程序时,如果你在上次保存字节码之后没有修改过源代码的话,Python将会加载.pyc文件并跳过编译这个步骤。当Python必须重编译时,它会自动检查源文件和字节码文件的时间戳:如果你又保存了源代码,下次程序运行时,字节码将自动重新创建。
9、写代码
a.实现用户输入用户名和密码,当用户名为 ?seven ?且 ?密码为 ?123 ?时,显示登陆成功,否则登陆失败!
username=input("username:")
passwd=input("passwd:")
if username=="seven" and passwd=="123":
print("登录成功!")
else:
print("登录失败!")
b.实现用户输入用户名和密码,当用户名为 ?seven ?且 ?密码为 ?123 ?时,显示登陆成功,否则登陆失败,失败时允许重复输入三次
count=0
while True:
username = input("username:")
passwd = input("passwd:")
if username=="seven" and passwd=="123":
print("登录成功!")
break
count += 1
if count==3:
print("登录失败!")
break
10、写代码
a. ?使用 while 循环实现输出 2 ??‐ ?3 ?+ ?4 ?‐ ?5 ?+ ?6 ?... ?+ ?100 ?的和
i=2
total_1=0
total_2=0
while i<=100:
if i%2==0:
total_1+=i
else:
total_2+=-i
i+=1
total=total_1+total_2
print(total)
b. ?使用 for 循环和 range 实现输出 ?1 - 2 ?+ ?3 ?-? 4 ?+ ?5 ?-? 6 ?... ?+ ?99 ?的和
total_1=0
total_2=0
for i in range(100):
if i%2==1:
total_1+=i
else:
total_2+=-i
total=total_1+total_2
print(total)
c. ?使用 while 循环实现输出 ?1,2,3,4,5, ??7,8,9, ???11,12
i=1
while True:
if i>=1 and i<=5:
print(i)
if i>=7 and i<=9:
print(i)
if i==11 or i==12:
print(i)
i+=1
d. ?使用 while 循环实现输出 ?1‐100 ?内的所有奇数
i=1
while i<=100:
if i%2==1:
print(i)
i+=1
e. ?使用 while 循环实现输出 ?1‐100 ?内的所有偶数
i=1
while i<=100:
if i%2==0:
print(i)
i+=1
11、分别书写数字 ?5,10,32,7 的二进制表示
数字5: 00000101
数字10: ?00001010
数字32: 00100000
数字7: 00000111
12、简述对象和 ?类的关系(可用比喻的手法)
类是具有相同数据结构(属性)和相同操作功能(行为)对象的集合。对象就是符合某种类所产生的一个实例。
13、现有如下两个变量,请简述 ?n1 ?和 ?n2 ?是什么关系?
n1 ?= ?123
n2 ?= ?123
n1和n2使用同一内存地址
python内部的优化:?-5到157之间的赋值变量都是相同的地址
14、现有如下两个变量,请简述 ?n1 ?和 ?n2 ?是什么关系?
n1 ?= ?123456
n2 ?= ?123456
n1和n2使用不同的内存地址
python内部的优化:?-5到157之间的赋值变量都是相同的地址
15、现有如下两个变量,请简述 ?n1 ?和 ?n2 ?是什么关系?
n1 ?= ?123456
n2 ?= ?n1
使用同一内存地址,只是变量名不同
16、如有一下变量 n1 ?= ?5,请使用 int 的提供的方法,得到该变量最少可以用多少个二进制位表示?
3个二进制位表示,00000101
17、布尔值分别有什么?
True和False
在二进制中的0、1。很多情况下,0被认为是False,所有的非0均被认为是True。
18、阅读代码,请写出执行结果
a ?= ?"alex"
b ?= ?a.capitalize()
print(a)
print(b)
请写出输出结果:alex ? Alex ?#capitalize() 首字母大写其他字母小写
19、写代码,有如下变量,请按照要求实现每个功能
name ?= ?" ?aleX"
a.移除 name 变量对应的值两边的空格,并输入移除后的内容
name=" aleX"
print(name.strip())
b.判断 name 变量对应的值是否以 ?"al" ?开头,并输出结果
name=" aleX"
if name[0:2]=="al":
print("True")
else:
print("False")
输出False
方法二:print(name.startswith("al")) False
c.判断 name 变量对应的值是否以 ?"X" ?结尾,并输出结果
name=" aleX"
if name[-1]=="X":
print("True")
else:
print("False")
输出True
方法二:print(name.endswith("X"))???? True
d.将 name 变量对应的值中的 ?“l” ?替换为 ?“p”,并输出结果
name=" aleX"
print(name.replace("l","p"))
输出:apeX
e.将 name 变量对应的值根据 ?“l” ?分割,并输出结果。
name=" aleX"
print(name.split("l"))
输出:[' ?a', 'eX']
f.请问,上一题 ?e ?分割之后得到值是什么类型?
name.split("l") ?#把字符用“l”分割成列表list
g.将 name 变量对应的值变大写,并输出结果
name=" aleX"
print(name.upper())
输出:? ALEX
h.将 name 变量对应的值变小写,并输出结果
name=" aleX"
print(name.lower())
输出:? alex
i.请输出 name 变量对应的值的第 2 个字符?
name=" aleX"
print(name[1])
输出:a
j.请输出 name 变量对应的值的前 3 个字符?
name=" aleX"
print(name[0:3])
输出:?al
k.请输出 name 变量对应的值的后 2 个字符?
name=" aleX"
print(name[-2:])
输出:eX
l.请输出 name 变量对应的值中 ?“e” ?所在索引位置?
name=" aleX"
print(name.index("e"))
输出:3
20、字符串是否可迭代?如可以请使用 for 循环每一个元素?
name="aleX"
for i in range(len(name)):
print(name[i])
21、请用代码实现:利用下划线将列表的每一个元素拼接成字符串,li ?= ?['alex', ?'eric', ?'rain'] ?
li=['alex','eric','rain']
print('_'.join(li))
输出:alex_eric_rain
li = ['alex', 'eric', 'rain']
li=['alex','eric','rain']
print(len(li))
输出:3
li=['alex','eric','rain']
li.append('seven')
print(li)
输出:['alex', 'eric', 'rain', 'seven']
li=['alex','eric','rain']
li.insert(0,'tony')
print(li)
输出:['tony', 'alex', 'eric', 'rain']
li=['alex','eric','rain']
li[1]="kelly"
print(li)
输出:['alex', 'kelly', 'rain']
li=['alex','eric','rain']
li.pop(1)
print(li)
输出:['alex', 'rain']
li=['alex','eric','rain']
li.remove("eric")
print(li)
输出:['alex', 'rain']
li=['alex','eric','rain']
print(li[1])
li.pop(1)
print(li)
输出:eric
['alex', 'rain']
li=['alex','eric','rain']
li.pop(2)
print(li)
输出:['alex', 'eric']
li=['tony','alex','eric','rain','seven']
del li[1:4]
print(li)
输出:['tony', 'seven']
li=['tony','alex','eric','rain','seven']
li.reverse()
print(li)
输出:['seven', 'rain', 'eric', 'alex', 'tony']
li=['tony','alex','eric','rain','seven']
for i in range(len(li)):
print(li.index(li[i]),li[i])
输出:0 tony
1 alex
2 eric
3 rain
4 seven
li=['alex','eric','rain']
for i,j in enumerate(li):
print(i+100,j)
输出:100 alex
101 eric
102 rain
li=['tony','alex','eric','rain','seven']
for i in range(len(li)):
print(li[i])
输出:tony
alex
eric
rain
seven
li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
print(li[2][1][1])
li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
print(li[2][2].upper())
tu = ('alex', 'eric', 'rain')
print(len(tu))
输出:3
tu = ('alex', 'eric', 'rain')
print(tu[1])
输出:eric
tu = ('alex', 'eric', 'rain')
print(tu[0:2])
输出:('alex', 'eric')
tu = ('alex', 'eric', 'rain')
for i in range(len(tu)):
print(tu[i])
输出:alex
eric
rain
e. 请使用for、len、range输出元组的索引
tu = ('alex', 'eric', 'rain')
for i in range(len(tu)):
print(i,tu[i])
输出:0 alex
1 eric
2 rain
tu = ('alex', 'eric', 'rain')
for i,j in enumerate(tu):
print(i+10,j)
输出:10 alex
11 eric
12 rain
和列表一样,但元组是只可读的,不可修改。
不可被修改,元组明确规定存储的数据不应该被修改,强制变更list后可以进行修改。
k2为列表,可以被修改。
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
tu[1][2]["k2"].append("seven")
print(tu)
输出:('alex', [11, 22, {'k1': 'v1', 'k2': ['age', 'name', 'seven'], 'k3': (11, 22, 33)}, 44])
k3为元组,不可以被修改。以下为强制修改:
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
k3为元组部分里的字典中的key
tu[1][3]["k3"]=list(tu[1][3]["k3"])
tu[1][3]["k3"].append("seven")
tu[1][3]["k3"]=tuple(tu[1][3]["k3"])
print(tu)
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
for key in dic.keys():
print(key)
输出:k1
k2
k3
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
for value in dic.values():
print(value)
输出:v1
v2
[11, 22, 33]
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
for i ,j in dic.items():
print(i,j)
输出:k1 v1
k2 v2
k3 [11, 22, 33]
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
dic["k4"]="v4"
print(dic)
输出:{'k1': 'v1', 'k2': 'v2', 'k3': [11, 22, 33], 'k4': 'v4'}
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
dic["k1"]="alex"
print(dic)
输出:{'k1': 'alex', 'k2': 'v2', 'k3': [11, 22, 33]}
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
dic["k3"].append(44)
print(dic)
输出:{'k1': 'v1', 'k2': 'v2', 'k3': [11, 22, 33, 44]}
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
dic["k3"].insert(0,18)
print(dic)
输出:{'k1': 'v1', 'k2': 'v2', 'k3': [18, 11, 22, 33]}
s="alex"
s=list(s)
print(type(s))
输出:<class 'list'>
s="alex"
s=tuple(s)
print(type(s))
输出:<class 'tuple'>
li=["alex","seven"]
li=tuple(li)
print(type(li))
输出:<class 'tuple'>
tu = ('Alex', "seven")
tu=list(tu)
print(type(tu))
输出:<class 'tuple'>
d. 将列表 li = ["alex", "seven"] 转换成字典且字典的key按照 10 开始向后递增
li = ["alex", "seven"]
dir={}
a=10
for i in li:
dir[a]=i
a+=1
print (dir)
输出:{10: 'alex', 11: 'seven'}
n="老男孩"
n1=n.encode("utf-8")
print(n1)
n2=n1.decode("utf-8")
print(n2)
输出:b'\xe8\x80\x81\xe7\x94\xb7\xe5\xad\xa9'
老男孩
n="老男孩"
n1=n.encode("gbk")
print(n1)
n2=n1.decode("gbk")
print(n2)
输出:b'\xc0\xcf\xc4\xd0\xba\xa2'
老男孩
更多编码问题链接:http://www.cnblogs.com/yuanchenqi/articles/5956943.html
sum=0
for i in range(101):
sum+=i
print(sum)
输出:5050
tu=[11,22,33,44,55,66,77,88,99,90]
n1=[]
n2=[]
dir={}
for i in tu:
if i >66:
n1.append(i)
else:
n2.append(i)
dir["k1"]=n1
dir["k2"]=n2
print(dir)
输出:{'k1': [77, 88, 99, 90], 'k2': [11, 22, 33, 44, 55, 66]}
goods = [
{"name": "电脑", "price": 1999},
{"name": "鼠标", "price": 10},
{"name": "游艇", "price": 20},
{"name": "美女", "price": 998},
]
goods_cart=[]
while True:
salary=input("input your salary:")
if salary.isdigit():
salary=int(salary)
while True:
print("编号", "商品","\t", "价格")
for i in range(len(goods)):
print(i+1,"\t",goods[i]["name"],"\t",goods[i]["price"])
choice=input(">>:").strip()
if choice.isdigit():
choice=int(choice)
if choice>0 and choice<=(len(goods)-1):
if salary-goods[choice-1]["price"]>=0:
salary-=goods[choice-1]["price"]
goods_cart.append(goods[choice])
print(goods[choice-1]["name"],"加入购物车,购买成功",
"还剩余额",salary)
else:
print("余额不够,无法购买,还差",goods[choice-1]["price"]-salary)
if choice=="q":
print("你购买的商品是",goods_cart,"还剩",salary,"元")
break
else:
print("你输入的商品不存在!")
break
print("欢迎下次光临!")
具体注释:链接http://www.cnblogs.com/xuyaping/p/6639850.html
本文系转载,前往查看
如有侵权,请联系?cloudcommunity@tencent.com 删除。
本文系转载,前往查看
如有侵权,请联系?cloudcommunity@tencent.com 删除。