Python语法

Python语法

1.print

print在Python中提供打印输出的功能,是将Python中的数据输出到控制台。

print()

2.注释

含义:对代码进行解释和说明,目的就是让别人和自己能够清晰的看懂代码的含义,提高代码的可读性。

注释是不会被计算机识别的 一般写注释的时候写在代码的上方或者右方。

注释另外的作用:修改代码的时候,可能代码需要调试,有部分代码用不到,没有必要删除,可以给注释掉。

单行注释 : #空格 快捷键 ctrl+/ 去掉注释也一样ctrl+/

多行注释 : 三对引号[英文格式下] 单引号也可以双引号也可以。

'''
多行注释
'''

3.行和缩进

编程语言:由多条语句按照相应的逻辑实现代码,编写相应的程序的。

​ 语句都有相应的结束标记,一般编程语言语句的结束标记是分号;。

在Python中,建议语句的结束不写分号,也可以写【但是会报警告】。

建议:一行一条语句【如果一行中有多条语句,语句结束必须加分号—这种方式不建议】

print('hello');print('world')

缩进:在代码前面不要随意加空格或者tab键。

4.标识符与关键字

标识某个实体的符号,使用这个符号可以代替实体进行相应的运算

在编程语言中,标识符一般就是给变量、项目名称、文件名称、函数名、类名等等自定义名称,建立起名称和使用的数据之间的关系。

自定义名称要遵循一定的规则:

  1. 标识符是由数字、字母、下划线组成。

  2. 标识符名称不能以数字开头。

  3. 不能使用关键字与保留字。

    1. 关键字:编程语言中具有特殊含义的单词

      ​ Python环境中自带了很多工具包,每个工具包都有对应的作用。比如:time–包含时间相关的操作。

      ​ 要想使用工具包,需要导包。

      ​ 语法:import 工具包名

      ​ 使用工具包下面的内容:工具包名.内容名

      # 打印当前时间,需要获取time工具包
      import time
      # 当前时间的操作
      print(time.localtime())
      
    2. 保留字:编程语言中已经使用的名称,不建议再使用【因为再使用的话,会覆盖掉原本的含义】

# 1.标识符是由数字、字母、下划线组成。

# 打印一个数据10
print(10)   # 10
# 定义一个标识符,给它赋值为10
num = 10
print(num)  # 10

# 打印10+20的和
print(10+20)  # 30
print(num+20)  # 30

# 定义的时候不能包含其他符号,否则会报错
num@ = 10  # SyntaxError: invalid syntax
# 2.标识符名称不能以数字开头。
1_num = 10   # SyntaxError: invalid decimal literal
# 3.不能使用关键字与保留字。
# 3.1 不能使用关键字
"""
# python中的关键字,被放在 keyword的工具包
import keyword
# 获取所有的关键字的操作
print(keyword.kwlist)
'''
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 
 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal',
 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
'''
# 使用关键字定义名称,会报错
False = 10   # SyntaxError: cannot assign to False  不允许给False再次赋值
"""
# 3.2 不建议使用保留字
"""
# print 在Python中被使用了  具有输出的含义
print = 10  # print这个标识符 代表只是10  原本的输出的含义就被覆盖了
print(10)  # TypeError: 'int' object is not callable
# 怎么辨别是不是保留字: 写单词的时候被提示出来的都是Python中已经使用的了  就不再使用即可
"""

5.变量与数据类型

变量:变化的数据,这种变化的数据在程序中来使用的时候,一般会给数据做一个标记,方便获取相关的数据信息,这个标记就成为变量名。

​ 例如: 记录一天的气温

​ 在程序中使用这个气温的时候,具体使用哪个数据,就不确定了,一般会被这个数据值设置一个变量名,随着时间的推移 设置不同的数据值,当使用的时候直接使用这个标记名代替数据参与运算即可。

# 早晨温度
air_temp = 24
# 中午温度
air_temp = 30
print(air_temp)   # 30

数据类型:把相同特征的数据进行归类,形成一类数据,这个称为数据类型

Python中的数据类型

整数类型(整型int) 10 20 30 40

小数类型(浮点型float) 3.14 5.17

文本数据(字符串str)字符串数据是需要使用引号包含的[不区分单双引号] ‘hello’ “Nice” ‘’ [空字符串]

逻辑结果(布尔类型bool) 逻辑结果只有两种 成立与不成立,布尔值只有两个 True 和 False

空类型(NoneType) 空值(None) 代表什么都没有

空字符串和None不是一个东西 【空字符串理解成是空箱子 None连箱子都没有】

获取数据的类型 type变量名

类和对象

类:对具有相同属性和特征的数据的一个抽象描述【泛泛的称呼】

比如:整数类型

对象;该类下实际存在的实体

比如:10

# 定义一个 变量,记录人的名称,[起名字尽量见名知意]
name = '喜唐'
print(name)  # 喜唐
print(type(name))  # <class 'str'>    class代表的就是类型
# 定义一个变量 记录一个人的年龄
age = 30
print(age)  # 30
print(type(age))    # <class 'int'>  # 30
# 定义一个变量 记录性别
gender = '女'
print(gender)   # 女
print(type(gender))    # <class 'str'>
# 记录一个状态值
flag = True
print(flag)   # True
print(type(flag))     # <class 'bool'>
# 空值
result = None
print(result)  # None
print(type(result))     # <class 'NoneType'>

6.Python的输出

按住ctrl键点击要查看信息的名称,就可以进入到Python定义的源码文件

print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False)

value, ...代表print可以一次性输出多个数据,书写的时候数据之间使用逗号分隔

sep=' '一次性输出多个数据时,展示的结果中数据之间的分隔符 默认是空格

end='\n'输出内容结束符,print输出内容时,会在内容末尾追加一个结束符 默认是换行

字符串中特殊的符号 \ [转义符]:可以将某些符号的含义转变为其他的意思

n—\n 换行符

r—\r 回车 在windows系统下 存储数据的时候 \n 本质上存储的是\r\n(要写\r\n,\r\n会自动解读为\n,但\r不会)

t—\t 制表符 就是tab键

u— 这个识别成unicode编码符号

file=sys.stdout:print数据输出的目的地,默认就是控制台下

# 更新内容的输出目的地
把内容输出到文件中
1. 需要建立程序和文件之间的联系通道
    有一个操作 open(文件路径, 操作文件的模式, 文件的编码形式):以指定模式将文件与程序建立联系
        文件路径有两种格式:
    		a. 绝对路径
            	windows系统  从盘符开始 到 具体的文件的路径  就是绝对路径
                 	例如:D:\pythonproject1\静夜思.txt
            	Mac系统 从根路径 /开始到具体文件结束
                    	例如:/Users/各班代课/Python2304/day02_变量及其运算符/代码/静夜					思.txt
   			b. 相对路径[建议]
         		需要文件配置在项目路径下   
         		相对路径是有参照物的:当前正在编辑的文件  
         		相对路径中有两个特殊的符号:
            		.  ---  当前操作的文件所在的文件夹 pythonproject1
           			.. --- 当前操作的文件所在的文件夹上一级  D
        操作文件的模式
            r -- read  只读  在程序中要读取文件的数据
            w -- write  只写  要将信息从程序中写入到文件中
                    文件如果不存在 会自动创建文件
                    文件存在  会清空文件内容 再把数据写入
            a --append 只写  要将信息从程序中写入到文件中
                    文件不存在 会创建文件
                    文件存在 进行的是追加写的操作
        文件的编码形式 【不同的编码形式决定了文件中语言的类型】
            编码:人为规定一种编译规则  
                在计算机存储数据的时候,存储格式是 二进制形式的
                十进制数据  逢十进一  数字符号集 0 1 2 3 4 5 6 7 8 9 
                二进制数据  逢二进一  数字符号集 0 1
                
                但是数据存储的时候 并不是只有数字,还有汉字 英文字母等等
                十进制转化成二进制怎么转换的???
                    存储10  在计算机中的是什么样子???
                        除以2取余数  直到商为0  将所有的余数倒序拼接起来
                            10/2 = 5 ---- 0
                            5/2 = 2 ----- 1
                            2/2 = 1 ----- 0
                            1/2 = 0 ----- 1
                            
                            10 ====> 1010
                
                汉字、英文字母等等不能直接转化为二进制,因此就出现了编码
                计算机人为制造的,运算规则也是人为制造的
                
                汉字或者英文字母在存储的时候 指定了什么规则???  这个映射规则称为编码
                    将汉字或者英文字母 每一个字对应着一个数字 
                    例如
                       a ===> 97===> 27361
                    
                常见的编码规则有:
                    ASCII码  --- 只设置128个符号对应的数字  包括英文字母
                    GB2312 --- 国家编码标准 2312序列号
                    GBK --- 国标扩展   
                    Unicode --- 国际编码标准 【收录是世界语言在内的】
                        Python的编码就是unicode下UTF-8  
2. 通过通道把数据传递到文件中
"""
# 绝对路径示例:
handle=open('D:\喜唐的笔记\静夜思.txt','w',encoding='UTF-8')
print('床前明月光,疑是地上霜。',file=handle,flush=True)
# 相对路径示例:
handle1=open('.\静夜思.txt','w',encoding='UTF-8')
print('窗前明月光,疑是地上霜。',file=handle1)
handle2=open('..\李白.txt','w',encoding='UFT-8')
print('静夜思',file=handle2)

flush=False:是否快速的将通道中的数据输出到文件中

print(1,2,3,4)  # 1 2 3 4

# 自己设置多个数据之间的分隔符
# 如果直接使用逗号分隔 代表的输出的多个数据 为了区分是数据还是分隔符,给分隔符赋值的时候 sep=指定的分隔符
print(1,2,3,4,sep='+')  # 1+2+3+4

# 演示转义符
print('and')   # and
print('a\nd')
'''
a
d
'''
print('1\r\n2')
'''
1
2
'''
# 输出内容的时候 此时不需要换行 可以修改end的值
print('hello',end='\t')
print('world')  #  hello	world
# \u  每一个unicode编码值 都对应着一个文字
print('\u4e00')     # 一

# 有些情况下,不需要转义符进行转义,保持转义符的本意.比如:路径中 C:\users\...
# 方式1: 对转义符再次转义  \\  保持\本身的含义
print('\\u')   # \u
# 方式2: 使用r修饰字符串   字符串中每个符号都保持数据本身的含义
print(r'\u')   # \u

7.Python中的输入

input让用户在控制台输入数据,传递到程序中。

格式:input(提示语)----会让程序暂停

​ 如何让程序继续:在控制台上输入数据,结束输入的标记是回车,输入数据回车之后,就把控制台输入的数据传递到程序中,想要获取这个数据,需要接收。

注意:输入的数据是变化的【也就是变量】,想要获取变量的数据,需要给变量的值一个标记名【变量名】。

# 将用户在控制台输入的数据 赋值给name这个变量名
name = input('请输入你的姓名:')
print('打印name的值',name)

# 不管录入的数据格式是什么样的,在程序中变量的值永远都是字符串类型的。
value = input('请输入一个内容:')
print(type(value))    # <class 'str'>

8.类型转换

# 用户输入两个数,求和
num1 = input('请输入一个数字:')   # 11
num2 = input('请输入另一个数字;')  # 12
print('这两个数字的和',num1+num2)   # 这两个数字的和 1112

# 这个结果的原因是:input 不管用户输入的是什么格式的数据 在程序中拿到的都是字符串类型的
字符串数据之间进行相加 完成的是拼接的动作
print('a'+'b')   # ab

# 想要完成这个求和这个目的,num1和num2接收到数据类型得是整数类型的才可以,但是现在是字符串类型的,想让字符串格式的数值变成整数类型,就需要进行类型转换
  操作语法【这个格式是固定的】
     int(数据/变量名)
# 类型转换示例:
value = '1990'
print(type(value))   # <class 'str'>
num = int(value)
print(type(num))     # <class 'int'>
# 注意事项: 把字符串格式的数值转化为整型时  数值的格式必须满足整数形态
int('3.14') # ValueError: invalid literal for int() with base 10: '3.14' 不合法的数据
int('11a')  # ValueError: invalid literal for int() with base 10: '11a' 不合法的数据

# 改进:转换为整型,并赋值给num1和num2
num1 = int(input('请输入一个数字:'))    # 11
num2 = int(input('请输入另一个数字;'))   # 12
print('这两个数字的和',num1+num2)       # 这两个数字的和 23

# 把字符串数据转化成浮点型 
float(数据/变量名)
注意:转换的时候要满足数字的形态  【可以是整数 也可以小数】

data = '3.14'
res = float(data)
print(type(res))  # <class 'float'>

data = '11'
res = float(data)
print(type(res))  # <class 'float'>

9.运算符

算术运算符

一元运算符:正负号 +11 -11

二元运算符

加法+

减法-

乘法*

除法/ 和 //

取余%

幂数**

优先级别:幂数** > 负号 > 乘、除、余 > 加、减

提高运算符的优先级别 使用()包含 不管多少层都是()

复合赋值运算符

简单的赋值运算符 = :a=10[将等号右边的数据赋值给左边的变量名]

复合赋值运算符:在进行赋值的时候,先操作了算术运算

+=-=*=/=//=%=**=

比较运算符: 比较两个数据,判断大小

>判断前者是否大于后者

>=判断前者是否大于或者等于后者

<判断前者是否小于后者

<=判断前者是否小于或者等于后者

==判断前者是否等于后者

!=判断前者是否不等于后者

比较运算符运行结果是布尔类型的,结果只有两个值True和False

算数运算符优先级别高于比较运算符

逻辑运算符: 是来操作逻辑关系的

逻辑与 and

连接的条件必须同时成立【也就是条件之间是并且的关系】,结果才是成立的

逻辑或 or

连接的条件成立其中一个即可【也就是条件之间的关系是或者关系】

逻辑非 not

对条件结果进行取反操作【真变假,假变真】

比较运算符的优先级高于逻辑运算符

逻辑运算符中优先级别: not > and > or

成员运算符 in

成员: 众多中的一个,这个运算符是应用在容器型数据的元素判断的,判断数据是否在某个容器型数据中。

整数、小数、布尔值、空值 每个数据都是独立的个体,这些都不是容器型数据

字符串是一个容器型类型,元素是字符【长度为1的字符串称为字符, 比如’a’, ‘0’, ’ '】
字符串就是由0个或者多个字符拼接起来的
0个字符的情况下 称为空字符串 ‘’ [是个空箱子]

格式: 数据 in 容器型数据
逻辑:把数据当做一个整体,判断数据是否包含在容器中

格式: 数据 not in 容器型数据
判断数据是否不在容器中

# 算术运算符
a=9
b=2
print('加法',a+b)
print('减法',a-b)
print('乘法',a*b)
print('除法',a/b)  # 结果是浮点型的
print('向下整除',a//b)    # 有一个向下取整的操作: 结果是<=商 且最接近于商的整数
print('取余',a%b)     # 两数相除 获取余数
print('幂数',a**b)
'''
加法 11
减法 7
乘法 18
除法 4.5
向下整除 4
取余 1
幂数 81
'''
# 开方
# 对8开3次方,就是8的三分之一次方
print(8**(1/3))   # 2.0
# 复合赋值运算符
num = 125
num += 5  # num = num + 5 = 130
print(num)   # 130

num //= 6  # num = num // 6 = 21
print(num)   # 21

num %= 10  # num = num % 10 = 1
print(num)    # 1
# 比较运算符
a = 17
b = 9

res = a + b > b * 2
print(res)  # True

res = a - b <= a % b
print(res)  # True

# 判断一个数的个位数是否为7
# 获取数据的个位数????  除以10 取余数     比如 17除以10 商1 余7    16除以10商1余6
res = num % 10 == 7
print(res)  # True

# 如何获取十位上的数据????
"""
1.可以将十位上的数 处理成个位上的数  ===== 整除10    245//10 = 24
2.将处理后的结果对10取余   24 % 10=4
"""

# 判断一个数据是否是奇数  除以2余1
res = num % 2 == 1
print(res)

res = num % 2 != 0
print(res)
# 逻辑运算符

# 逻辑与 and
'''
大学中评奖学金   平均成绩和绩点
平均成绩在90以上 并且 绩点在4.5以上
定义两个变量 表示成绩和绩点
score = float(input('请输入平均成绩:'))
gpa = float(input('请输入绩点:'))
res = score > 90 and gpa > 4.5
print(res)
'''


# 逻辑或 or
'''
条件1 or 条件2
    其中一个条件成立即可
'''
# 判断一个年是否为闰年
'''
闰年:分为普通闰年和世纪闰年
    普通闰年: 能被4整除但是不能被100整除   2020年
    世纪闰年: 能被400整除  2000年
    
    普通闰年和世纪闰年满足其中一个要求 就是闰年 
'''
'''
year = int(input('请输入年份:'))
common = year % 4 == 0 and year % 100 != 0
century = year % 100 == 0
res = common or century
print(res)

# 判断输入的月份是否是第三季度的  7月8月9月
'''
month = int(input('月份:'))
res = month == 7 or month == 8 or month == 9
print('输入的月份是否是第三季度的结果:', res)
'''


# 逻辑非 not
"""
对逻辑结果取反,not条件
如果条件成立,not之后为False
如果条件不成立,not之后为True
"""
# 判断一个数是否为奇数
'''
num = int(input('输入一个数:'))
# num % 2 !=0   不等于0就是对等于0进行取反
# num % 2 ==1
res = not(num % 2 == 0)
print(res)
'''

# 判断一个数是否能被3或者7整除 但是不能同时被3和7整除
'''
num = int(input('请输入一个数字:'))
res = (num % 3 == 0 or num % 7 == 0) and not(num % 3 == 0 and num % 7 == 0)
print(res)
'''
# 成员运算符

s = 'hello'
res = 'h' in s
print(res)

res = 'hl' in s
print(res)


res = 'hl' not in s
print(res)

10.分支结构语句

分支结构语句有三种形态:

1.单分支结构

​ 在顺序流程过程中,检测数据是否达到某个状态点,如果达到这个状态点按照状态点的流程进行操作。如果没有达到的话,按照原流程进行操作。

例如:
学校 — 回家
如果时间比较早 在6点之前到家 先去洗车 —再回家

语法:
if 条件:
满足条件执行的操作
解读: 如果条件满足 就执行相应的操作
注意: 相应的操作的执行 要看条件是否满足 体现这种关系使用的是代码块包含的结构
Python中如何体现代码块包含: 使用冒号+四个空格的缩进 【一般编辑器会默认一个tab键 就是四个空格】

print('从学校出发')
# 需要记录当前的时间点
hour = 17
# 要求时间在18点之前,进行洗车的操作
if hour < 18:
    print('洗车店')
print('回家')

2.双分支结构

相当于十字路口,是向左还是向右
语法
if 条件:
满足条件执行的操作
else:
不满足条件执行的操作
解读:
如果条件满足,做事情A ,否则做事情B

# 做一个成绩判定器: 判断输入的成绩是及格还是不及格
score = float(input('成绩:'))
if score >= 60:
    print('合格')
else:
    print('不合格')

3.多分支结构

出现了3种及其以上的选择
语法
if 条件1:
操作1
elif 条件2:
操作2

elif 条件n:
操作n
else:
以上条件都不满足,执行的操作

这个else语句可以省略
elif ==== else if
如果与否则是对立面, 执行了如果,就不会执行否则

# 给成绩分等级
'''
    >= 90  A
    >= 80  B
    >= 70  C
    >= 60  D
    <60    E
'''
score = float(input('请输入成绩:'))
if score >= 90:
    print('A')
elif score >= 80:
    print('B')
elif score >= 70:
    print('C')
elif score >= 60:
    print('D')
else:
    print('E')

分支语句嵌套

在满足某个条件的基础上还需要再次进行逻辑判断

"""
需求:
    计算加油的金额
    因为油号不同 价格不同 优惠也是不一样
    92  单价8元/L   添加30L及其以上  打8折 否则按照原价处理
    95  单价8.8元/L  添加25L及其以上  打8折  否则按照原价处理
    98  单价9.5元/L   添加20L及其以上  打9折  25L及其以上8.5折  30L及其以上8折 否则按照原价处理
"""
oil_num = int(input('请输入油号:'))
litre = float(input('加油的升数:'))
# 判断油号
if oil_num == 92:
    # pass
    if litre >= 30:
        payment = 8 * litre * 0.8
    else:
        payment = 8 * litre
elif oil_num == 95:
    # pass
    if litre >= 25:
        payment = 8.8 * litre * 0.8
    else:
        payment = 8.8 * litre
else:
    # if litre >= 30:
    #     payment = 9.5 * litre * 0.8
    # elif litre >= 25:
    #     payment = 9.5 * litre * 0.85
    # elif litre >= 20:
    #     payment = 9.5 * litre * 0.9
    # else:
    #     payment = 9.5 * litre
    if litre < 20:
        payment = 9.5 * litre
    elif litre < 25:
        payment = 9.5 * litre * 0.9
    elif litre < 30:
        payment = 9.5 * litre * 0.85
    else:
        payment = 9.5 * litre * 0.8
print('加油的金额为:',payment)

11.循环结构语句

循环:周而复始 重复做同一件事
一直重复操作,没有终止,在编程里称为死循环 【在程序中是要避免的 — 程序卡死】
常见的循环结束状态:

  1. 循环满N次 比如:体育测试:围着操场跑满5圈
  2. 循环达到某个条件 比如: 体育测试:跑满1000米

Python提供的循环操作,有两个结构:

  1. for-in循环,适合于循环满N次的情景

    本质上是在遍历[逐个获取]容器型数据,在遍历获取元素的过程中进行相应的逻辑判断,容器中有几个元素,这个循环就执行几次。
    语法
    for 变量名 in 容器型数据:
    循环体
    解读:
    in 可以理解成进入容器中拿元素数据
    变量名 in进入拿到数据之后 赋值给变量名
    循环结束点: in到容器中 没有数据可拿的时候 循环结束

  2. while循环

# for-in循环

s = "hello"
# 逐个将字符串s中的元素取出来
for c in s:
    print(c)
    # print('跑了一圈')
# 获取字符串中小于l的字符
# 逻辑 获取到元素之后 要对其进行判断  判断是否是小于l的
for d in s:
    if d < 'l':
        print(d)


# 假如跑100圈  使用循环的时候 可以使用range快速生成一个等差数列
"""
range(stop)
    设定一个结束值, 等差数列是从0开始 步长为1 到stop[不包含]结束
        range(10) ====> 0 1 2 3 4 5 6 7 8 9 
range(start, stop)
    设定了起始值和结束值 等差数列是从start[包含]开始 步长为1 到stop[不包含]结束
        range(1, 11) ====> 1 2 3 4 5 6 7 8 9 10 
range(start, stop, step)
    step步长  
        正数 --- 生成的是递增的等差数列  要求 起始值<结束值    
        负数 --- 生成的是递减的等差数列  要求 起始值>结束值
    stop结束位置[不包含]
    start开始位置[包含]
        range(1, 10, 2) ====> 1 3 5 7 9 
        range(10, 0, -2) ====> 10 8 6 4 2 
range(100) ===> 0-99
"""
# 跑第几圈
for x in range(1,101):
    print('跑第',x,'圈')

for y in range(0,100,4):
    print(y)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值