各位小伙伴想要博客相关资料的话关注公众号:chuanyeTry即可领取相关资料!
计算机中所有的数据本质上都是以0和1的组合来存储。
在计算机中会将中文内存转换成 01010101010… ,最终存储到硬盘上。
在计算机中有这么一个编码的概念(密码本)。
一 -> 01111111 00011010 010110110
个 -> 01001111 10010000 001110100
人 -> 11111111 00000000 010101010
在计算机中有很多种编码。
每种编码都有自己的一套密码本,都维护这自己的一套规则,如:
utf-8编码:
一 -> 01111111 00011010 010110110
个 -> 01001111 10010000 001110100
人 -> 11111111 00000000 010101010
gbk编码:
一 -> 11111111 00000010
个 -> 01001111 01111111
人 -> 00110011 10101010
所以,使用的不同的编码保存文件时,硬盘的文件中存储的0/1也是不同的。
注意事项:以某个编码的形式进行保存文件,以后就要以这种编码去打开这个文件。否则就会出现乱码。
UTF-8编码去保存武沛齐:01111111 00011010 010110110 01001111 10010000 001110100 11111111 00000000 010101010
GBK编码形式去打开:乱码
编码必须要保持:保存和打开一直,否则会乱码。
默认Python解释器是以UTF-8编码的形式打开文件。如果想要修改Python的默认解释器编码,可以这样干:
# -*- coding:gbk -*-
print("我是爷")
建议:所有Python代码文件的都要以UTF-8编码保存和读取。
将结果或内容想要呈现给用户。
print("看着风景美如画")
print(" * * ")
print(" * * * * ")
print(" * * * * * * ")
print(" * * * * * * * * ")
print(" * * * * * * * * * * ")
print(" * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
print(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * ")
关于输出:
默认print在尾部会加换行符
print("看着风景美如画")
print("本想吟诗增天下")
输出:
看着风景美如画
本想吟诗增天下
想要不换行,则可以这样干
print("看着风景美如画",end="")
print("本想吟诗增天下",end="")
输出:
看着风景美如画本想吟诗增天下
print("看着风景美如画",end=",")
print("本想吟诗增天下",end=".")
输出:
看着风景美如画,本想吟诗增天下.
刚上学时,老师教我们 数字 、拼音、汉字、真假判断 等,然后我们根据学到的内容写作文,老师来检查并打分。
现在学编程,我教大家 int、str、bool 等,然后大家根据这些内容来写代码,写完代码交给Python解释器去运行。
整形,整数。
整型,其实就是以前数学课上讲的整数(不包含小数),在写代码时用于表示整数相关的东西,例如:年龄、存款、尺寸、手机号等。
一般我们提到的:5、18、22、99、… 等整数 在Python中都称为是整型,且支持 加/减/乘/除/取余/指数 等操作。
print(666)
print(2 + 10)
print(2 * 10)
print(10 / 2)
print(10 % 3)
print(2 ** 4)
字符串,其实就是我们生活中的文本信息。例如:姓名、地址、自我介绍等。
字符串有一个特点,他必须由引号引起来,如:
单行字符串
print("我是Alex")
print('我是Alex')
print('我是"alex')
print("中国北京昌平区")
多行字符串
print("""中国北京昌平区""")
print('''中国北京昌平区''')
对于字符串:
加,两个字符串可以通过加号拼接起来。
print( "alex" + "是金角大王吧" )
乘,让整形和字符串进行相乘,以实现让字符串重复出现N次并拼接起来。
print(3 * "我想吃饺子")
布尔类型中共有两个值:True / False
print(1 > 2)
print(False)
print(1 == 1)
print(True)
name = input("请输入你的用户名:")
if name == "alex":
print("用户登录成功")
else:
print("用户登录失败")
补充:
1 > 2
1 == 3
"alex" == "eric"
1 == "alex"
1 > "alex" 是无法进行比较大小
上文数据类型int/str/bool有了初步了解,他们都有自己不同的定义方式。
不同的数据类型都有不同的功能,例如:整型可以加减乘除 而 字符串只能加(拼接)和乘法。
如果想要做转换可遵循一个基本规则:想转换什么类型就让他包裹一些。
例如:str(666) = "666"是将整型转换为字符串、int(“888”)是将字符串转 888。
转换为整形:
# 字符串转换为整形(度可度之人)
int("666")
int("999")
"6" + "9" 的结果应该是: "69"
int("6") + int("9") 的结果是:15
int("alex是sb") 报错
# 布尔类型转换为整形
int(True) 转换完等于 1
int(False) 转换完等于 0
转换为字符串
# 整形转字符串
str(345)
str(666) + str(9) 结果为:"6669"
# 布尔类型转换为字符串
str(True) "True"
str(False) "False"
转换为布尔类型
# 整形转布尔
bool(1) True
bool(2) True
bool(0) False
bool(-10) True
# 字符串转布尔
bool("alex") True
bool("砂玻帮你") True
bool("") False
bool(" ") True
三句话搞定类型转换:
其他所有类型转换为布尔类型时,除了 空字符串、0以为其他都是True。
字符串转整形时,只有那种 “988” 格式的字符串才可以转换为整形,其他都报错。
想要转换为那种类型,就用这类型的英文包裹一下就行。
str(...)
int(...)
bool(...)
变量,其实就是我们生活中起别名和外号,让变量名指向某个值,格式为: 【变量名 = 值】,以后可以通过变量名来操作其对应的值。
name = "武沛齐"
print(name) # 武沛齐
age = 18
name = "alex"
flag = 1 > 18
address = "北京昌平" + "沙河"
addr = "北京昌平" + "沙河" + name # "北京昌平沙河alex"
print(addr)
print(flag)
age = 18
number = 1 == 2
注意:
age = 18
age=18
age = 18
name = "alex"
flag = 1 > 18
address = "北京昌平" + "沙河"
三个规范(只要有一条就会报错):
变量名只能由 字母、数字、下划线 组成。
不能以数字开头
na9me9 = "alex"
不能用Python内置的关键字
def = "alex"
break = 123
[‘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’]
两个建议:
下划线连接命名(小写)
father_name = "wupeiqi"
brother_age = 19
见名知意
age = 18
color = "red"
current_user_name = "吉诺比利"
通过学习上述变量知识让我们对变量了有了初步认识,接下来我们就要从稍稍高级一些的角度来学习变量,即:内存指向(在电脑的内存中是怎么存储的)。
情景一
name = "wupeiqi"
在计算机的内存中创建一块区域保存字符串”wupeiqi”,name变量名则指向这块区域。
情景二
name = "wupeiqi"
name = "alex"
在计算机的内存中创建一块区域保存字符串”wupeiqi”,name变量名则指向这块区域。然后又再内存中创建了一块域保存字符串”alex”,name变量名则指向”alex”所在的区域,不再指向”wupeiqi”所在区域(无人指向的数据会被标记为垃圾,由解释器自动化回收)
情景三
name = "wupeiqi"
new_name = name
在计算机的内存中创建一块区域保存字符串”wupeiqi”,name变量名则指向这块区域。new_name变量名指向name变量,因为被指向的是变量名,所以自动会转指向到name变量代表的内存区域。
情景四
name = "wupeiqi"
new_name = name
name = "alex"
在计算机的内存中创建一块区域保存字符串”wupeiqi”,name变量名则指向这块区域(灰色线), 然后new_name指向name所指向的内存区域,最后又创建了一块区域存放”alex”,让name变量指向”alex”所在区域.
情景五
num = 18
age = str(num)
在计算机的内存中创建一块区域保存整型18,name变量名则指向这块区域。通过类型转换依据整型18再在内存中创建一个字符串”18”, age变量指向保存这个字符串的内存区域。
至此,关于变量的内存相关的说明已讲完,由于大家都是初学者,关于变量的内存管理目前只需了解以上知识点即可,更多关于内存管理、垃圾回收、驻留机制等问题在后面的课程中会讲解。
写代码时候,如果想要对某写内容进行注释处理,即:解释器忽略不会按照代码去运行。
单行注释
# 声明一个name变量
name = "alex"
age = 19 # 这表示当前用户的年龄
注意:快捷点 command + ? 、 control + ?
多行注释
# 声明一个name变量
# 声明一个name变量
# 声明一个name变量
name = "alex"
"""
多行注释内容
多行注释内容
多行注释内容
"""
age = 19
输入,可以实现程序和用户之间的交互。
# 1. 右边 input("请输入用户名:") 是让用户输入内容。
# 2. 将用户输入的内容赋值给name变量。
name = input("请输入用户名:")
if name == "alex":
print("登录成功")
else:
print("登录失败")
data = input(">>>")
print(data)
特别注意:用户输入的任何内容本质上都是字符串。
提示输入姓名,然后给姓名后面拼接一个“烧饼”,提示输入姓名,然后给姓名后面拼接一个“烧饼”,最终打印结果。
name = input("请输入用户名:")
text = name + "烧饼"
print(text)
提示输入 姓名/位置/行为,然后做拼接并打印:xx 在 xx 做 xx 。
name = input("请输入用户名:")
address = input("请输入位置:")
action = input("请输入行为:")
text = name + "在" + address + action
print(text)
提示输入两个数字,计算两个数的和。
number1 = input("请输入一个数字:") # "1"
number2 = input("请输入一个数字:") # "2"
value = int(number1) + int(number2)
print(value)
if 条件 :
条件成立之后的代码...
条件成立之后的代码...
条件成立之后的代码...
else:
条件不成立之后执行的代码...
条件不成立之后执行的代码...
条件不成立之后执行的代码...
name = input("请输入用户名:")
if name == "alex":
print("sb")
else:
print("db")
提醒:统一缩进问题(都是使用四个空格 = tab)。
name = input("请输入用户名:")
if name == "alex":
print("sb")
print("sb")
else:
print("db")
示例1
print("开始")
if True:
print("123")
else:
print("456")
print("结束")
# 输出结果
开始
123
结束
示例2
print("开始")
if 5==5:
print("123")
else:
print("456")
print("结束")
示例3
num = 19
if num > 10:
print("num变量对应值大于10")
else:
print("num变量对应值不大于10")
示例4
username = "wupeiqi"
password = "666"
if username == "wupeiqi" and password == "666":
print("恭喜你,登录成功")
else:
print("登录失败")
示例5
username = "wupeiqi"
if username == "wupeiqi" or username == "alex":
print("VIP大会员用户")
else:
print("普通用户")
示例6
number = 19
if number%2 == 1:
print("number是奇数")
else:
print("number是偶数")
number = 19
data = number%2 == 1
if data:
print("number是奇数")
else:
print("number是偶数")
示例7
if 条件:
成立
print("开始")
if 5 == 5:
print("5等于5")
print("结束")
if 条件A:
A成立,执行此缩进中的所有代码
...
elif 条件B:
B成立,执行此缩进中的所有代码
...
elif 条件C:
C成立,执行此缩进中的所有代码
...
else:
上述ABC都不成立。
num = input("请输入数字")
data = int(num)
if data>6:
print("太大了")
elif data == 6:
print("刚刚好")
else:
print("太小了")
score = input("请输入分数")
data = int(score)
if data > 90:
print("优")
elif data > 80:
print("良")
elif data > 70:
print("中")
elif data > 60:
print("差")
else:
print("不及格")
if 条件A:
...
elif 条件B:
...
if 条件A:
if 条件A1:
...
else:
...
elif 条件B:
...
模拟10086客服
print("欢迎致电10086,我们提供了如下服务: 1.话费相关;2.业务办理;3.人工服务")
choice = input("请选择服务序号")
if choice == "1":
print("话费相关业务")
cost = input("查询话费请按1;交话费请按2")
if cost == "1":
print("查询话费余额为100")
elif cost == "2":
print("交互费")
else:
print("输入错误")
elif choice == "2":
print("业务办理")
elif choice == "3":
print("人工服务")
else:
print("序号输入错误")