python基础——基础语法

文章目录

一、基础知识

1、字面量

在代码中,被写下来固定的值,称为字面量。

2、常用值类型

  • type(变量/字面量) 可看变量类型

3、注释

  • 单行注释:#

  • 多行注释:一堆三个双引号

    """
    python
    """

4、输入输出

1.input
name = input("提示内容")  //输入全是字符串,后续需要类型转换
2.print
money = 50
print("python")
print("钱包有:",money,"元")

5、数据类型转换

int(x)  
float(x)
str(x)

6、其他

1.python变量命名大小写敏感
2.**是指数,a**b表示a的b次方,还可以a**=b

二、字符串拓展

1、字符串定义

单/双/三引号都可以

/可以使用转义字符解除引号的效用
name = 'python'   //里面可以内含双引号
name = "python"		//里面可以内含单引号
name = """		
	p
	y
	t
	h
	o
	n
"""

2、字符串拼接

1.print('python' + 'is easy')  输出python is easy
2.age = '18'
print('I am' + age+'years old')  输出I am 18 years old
3.'python' +18是不行的,字符串不能通过+与非字符串类型拼接

3、字符串格式化

//%为占位符,将后面变量占到前面所需要的地方
1.age = '18'
message = 'I am %s years old' % age
2.不同类型,多种变量都可以
age1 = 18,age2=20 
message = "I am %s,she is %s" % (age1,age2) //此时整型转换成字符串格式进去

3.f"内容{变量}" 快速格式化,不过此时无法做精度控制
message = f"I am {age1},she is {age2}"

4.表达式格式化
messgae = "I am %d years old" % (1*1)
messgae = f"I am {1*1} years old" 

常见占位符

4、格式化精度控制

m.n来控制数据的宽度和精度

  • m,控制宽度,要求是数字(很少使用),设置的宽度小于数字自身,不生效(小数和小数点都进入精度计算)。
    宽度太多从左用控制替代,比如%3d,而整数是2,写成[空格][空格]2
  • .n,控制小数点精度,要求是数字,会进行小数的四舍五入

三、条件/循环语句

1、if

1.注意缩进~
if 要判断的条件:   //冒号不要忘记
	程序
elif 要判断条件:
	程序
else:
	程序
2.案例
import random
age = random.randint(1,100)
if age > 10 :
	print("11")
elif age > 8 :
	print("22")
else:
	print("33")

2、while

1.条件满足进入循环
while 条件:
	程序

3、for循环

与其他语言不太一样,对内容进行逐个处理

1.基础语法
for 临时变量 in 待处理数据集:
	程序
//待处理的数据集是序列类型,其内容是一个个依次取出来的一种类型,包括字符串,列表,元组等
案例:
name = "BUAA"
for x in name:
	print(x)
2.range语句
range(5)得到的是一个序列:[0,1,2,3,4]
range(5,10)得到的是[5,6,7,8,9]
range(5,10,2)得到的是[5,7,9]
与for结合
for x in range(5)
	程序

四、函数

1、函数定义

1.定义
def定义带有名称的函数
def 函数名(传入参数):
	函数体
	return 返回值

//无return时,是有返回值的,返回一个特殊字面量,类型是<class 'NoneType'>
//手动返回return none也行
//if判断中,none等同于false,一般函数中主动返回none,与if配合处理
//无内容变量,暂时不需要值,可以name = none
2.多返回值
def 函数名(传入参数):
	return 返回值1,返回值2
接收:var1,var2 = 函数名(参数)
3.函数调用
一个函数fnc(name,age,gender)
位置传参:可以fnc("b",18,"男")这样按照位置接收
关键字传参:可以fnc(age=18,gender="男",name="a")接收(不按位置)
混用:还可以func("a",gender="男",age=18)接收,混用是位置参数必须在前
4.缺省参数
def fnc(name,age,gender="男")  //设置默认值
调用时若不传参采用默认值
缺省参数必须统一在位置参数后面
5.不定长参数 
位置传递:def func(*args)   args是元组类型
关键字传递:def fnc(**kwargs)  kwargs是字典类型,传参必须是key=value形式
6.匿名函数
lambda定义匿名函数
lambda 传入参数:函数体   //函数体只能写一行,函数体直接将结果return

2、函数说明文档

def 函数名(传入参数):
	"""
	函数整体说明
	:param x:形参x说明
	:param y:形参y说明
	:return:返回值说明
	"""
	函数体
	return 返回值

3、global关键字

num = 200
def func():
	global num//此时num指定指代的全局变量num=200
	num=300  //num改动全局变量num就会变

五、数据容器

1、概念

批量存储数据。根据特点不同,比如是否支持重复元素,是否可以修改,是否有序等,分为五类,列表(list),元组(tuple),字符串(str),集合(set),字典(dict)

2、列表(list)

1.定义:变量名称 = [元素1,元素2,元素3,...]
2.空列表:变量名称 = [ ]    变量名称 = list()
//列表存储的数据可以为不同数据类型,且支持嵌套
3.读:arr[0]
或反向索引:从后向前开始,依次递减(-1,-2,-3...)

列表方法

3、元组(tuple)

可以封装多个,不同类型的元素,唯一区别就是一旦定义完成就不可以修改了。

1.定义:变量名称 = (元素1,元素2,元素3,...)
2.空列表:变量名称 = ()   变量名称 = tuple()
3.定义单个元素:变量名称 = (元素1,)   //单元素一定要加括号,不然类型是字符串
//元组内部也支持嵌套
4.读:arr[0]

元组方法

注意点:

//元组内部嵌套list,list是可以修改的
arr = (1,2,["1","2","3"])
arr[2][1]="4"是可以的

4、字符串(str)

1.str = "abcd"
可以通过str[0]读取
2.对于字符串的修改都无法在原来的基础上,只能得到新的字符串

字符串方法

5、序列的切片操作

  • 序列是指内容连续,有序,可使用下标索引的一类数据容器。
  • 列表、元组、字符串都可视为序列
  • 切片操作:从一个序列中,取出一个子序列
    语法:[起始下标:结束下标:步长]
    • 起始下标表示从何处开始,可以留空,留空视作从头开始
    • 结束下标(不含)表示何处结束,可以留空,留空视作截取到结尾
    • 步长表示,依次取元素的间隔
      • 步长1表示,一个个取元素
      • 步长2表示,每次跳过1个元素取
      • 步长N表示,每次跳过N-1个元素取
      • 步长为负数表示,反向取(注意,起始下标和结束下标也要反向标记)

6、集合(set)

  • 特点:不支持元素重复,内容无序

    1.定义:变量名称 = {元素1,元素2,元素3,...}
    2.空集合:变量名称 = {} 变量名称 = set{}
    //列表存储的数据可以为不同数据类型,且支持嵌套
    3.读:集合无序,因此不支持下标索引访问
    或反向索引:从后向前开始,依次递减(-1,-2,-3...)

集合方法

7、字典(dict)

1.定义:变量名称 = {key:value,key:value,....}
2.空字典:变量名称 = {}   变量名称 = dict{}
//字典的key不允许重复,重复添加等于覆盖原有数据。
//允许嵌套
3.读取:arr[key]
4.for x in dict: //每次取出来的是key

常见方法

8、通用操作

  • 类型转换

    list(容器) //字典转列表得到keys
    str(容器)
    tuple(容器)
    set(容器)
    其他容器类型很难转换成字典

六、文件操作

1、常见打开模式

2、读取操作

1.打开
open(name,mode,encoding)
name:是要打开的目标文件名的字符串(可以包含文件所在的具体路径)
mode:设置打开文件的模式(访问模式):只读、写入、追加等。
encoding:编码格式(推荐使用UTF-8)
# encoding的顺序不是第三位,所以不能用位置参数,用关键字参数直接指定
eg.f = open('python.txt','r',encoding='utf-8') 
2.读取
f.read(num)
num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据。
一次读取后则下次是从上次读取的地方继续读取
f.readlines()
readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。
f.readline()一次读取一行内容  一次读取后则下次是从上次读取的地方继续读取
3.关闭
f.close()  //不关闭则文件会一直被python文件占用
4.
with open(name,mode,encoding) as f:
	程序
通过在with open的语句块中对文件进行操作。可以在操作完成后自动关闭close文件,避免遗忘掉close方法

3、写文件

  • 直接调用write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区

  • 当调用flush的时候,内容会真正写入文件

  • 这样做是避免频繁的操作硬盘,导致效率下降(攒一堆,一次性写磁盘)

    1.打开文件 f = open(name,'w'/a)
    2.写入f.write(内容)
    3.f.flush()
    //注意f.close内置了flush方法,因此关闭前也会刷新
    //w和a在文件不存在都会创建文件,不过文件存在w会清空文件再写,a是追加在后面

相关推荐
网络点点滴11 分钟前
声明式和函数式 JavaScript 原则
开发语言·前端·javascript
查理零世1 小时前
保姆级讲解 python之zip()方法实现矩阵行列转置
python·算法·矩阵
刀客1231 小时前
python3+TensorFlow 2.x(四)反向传播
人工智能·python·tensorflow
stevewongbuaa1 小时前
一些烦人的go设置 goland
开发语言·后端·golang
撸码到无法自拔2 小时前
MATLAB中处理大数据的技巧与方法
大数据·开发语言·matlab
island13142 小时前
【QT】 控件 -- 显示类
开发语言·数据库·qt
sysu632 小时前
95.不同的二叉搜索树Ⅱ python
开发语言·数据结构·python·算法·leetcode·面试·深度优先
SsummerC2 小时前
【leetcode100】从前序与中序遍历序列构造二叉树
python·算法·leetcode
hust_joker3 小时前
go单元测试和基准测试
开发语言·golang·单元测试