引言
都是我手欠非要报什么python的计算机二级,现在好了假期不但要冲C艹,还要学个python,用了几天的时间速成了一下python的基础语法,其实在学会C的基础上,py学起来是非常的快啊。这篇博客呢,建议有一定语言基础的朋友来看。没有接触过编程的朋友可以先看看python相关书籍或视频从0到1学,这里我推荐蟒蛇的python,浅显易懂。那么就开始接下来的正文内容吧。
Python环境配置
想要进行Python开发,就要搭建好Python的环境
需要安装的环境主要是两个部分:
运行环境:Python开发环境:Pycharm安装Python
(1)找到官方网站
认准这个英文标了官方的网站,别的什么中文版官版什么的都别看,是假的,点进去都是收费的
(2)找到下载页面
点入网页后,鼠标放到download上,根据电脑配置点击,例如我的电脑是Windows系统,就点击Windows
点进去后会进入到这样一个页面里,你可能会注意到版本有非常之多,我们从左边随便点一个版本下就行,具体差异不是很大,注意,右边版本Pre-releases是最新一批版本,不够稳定,所以还是下左边较为稳定的版本,可不要下错了。由于python官网服务器在国外,所以下起来相对会比较慢,耐心等待一下就可以了,我这边其实是在联想的应用商店下的,官网在我这里不知为什么下的非常之慢
(3)安装
下好后咱们打开文件 ,会弹出安装界面。这里注意一点,要把下面的勾勾上,将Python加入路径中去,避免后续一系列问题。然后点击Install Now
当你看到这样的页面的时候,python解释器就已经下好了
这时候其实已经可以在控制台敲python的代码了,但是为了更舒适的写python代码,我们还需要安装一个集成开发环境,也就是pycharm。
安装pycharm
(1)找到官方网站
图中第一个就是官网了
进去后点击中间的download
(2)下载和安装
根据电脑配置下载,注意下社区版(Community),专业版要钱
打开文件点击next
这里文件下载路径根据需求就行
这里勾这两个
后面就没什么要注意的了,一路next就行,看到以下页面就是安装完成了
现在你已经可以点开pycharm开始写python代码咯!
Python中的打印,变量声明和数据类型
数据打印
print(1 + 2 - 3)print(1 + 2 * 3)print(1 + 2 / 3)
这里稍微注意一下python中除号(/)是直接将整型转化成了浮点型
数据类型
这里要说明的是,python中,初始化变量统统都不用事先声明类型了直接将数据用赋值运算符(=)赋给你初始化的变量就行,见下方代码
# 整型a = 1print(type(a))# 浮点型b = 2.2print(type(b))# 字符串类型c = 'hello'd = "world"print(type(c),type(d))# 布尔类型e = Truef = Falseprint(type(e))print(a)print(b)print(c)print(d)
下面是运行结果
这里稍微注意一下,type()是可以直接取到变量类型的内联函数 ,不用包含任何文件,可以直接调用
整型
python中的整型可以自动扩容(自带高精度),意思就是不再像C语言中不同的整型能存的数据大小有一个范围,在python中声明的整型的大小没有上限,可以随意的加减,不用考虑数据溢出的问题了
浮点型
python中的浮点型只存在一种类型,就是C语言中的double类型,看似类型打印的是float实则C中的float在python中已经不复存在
字符串类型
python中单引号和双引号引起来的都是字符串类型,但注意必须是英文字符的单引号和双引号
同时,如果字符串中有单引号,可以用双引号引起;如字符串中有双引号,同样也可以用单引号引起;如都有,可以选择使用三引号,三个'或者三个"都可以
a = "I' am a boy"b = 'hhh,"hello",hhh'# 三引号c = '''hh'hhh"h'hhh'''print(a)print(b)print(c)
下面是运行结果
同时python中字符串支持拼接
a = 'hello'b = ' world'c = a + bprint(a + b)print(c)
其实感觉这个学了C++的应该会熟悉,STL容器中string类就支持这样的操作
这里要注意的是:字符串和数字不可以混合相加,同时字符串直接也不支持减法运算
布尔类型
布尔类型只有真和假,主要用于逻辑判定
真(True)假(False)在JAVA和C/C++中,bool(布尔)类型为true和false,python中的bool类型首字符都是大写的,不要搞混了
如果将bool类型与整型进行加减运算,那么True会被转成1,而False会被转成0,但是这样的操作没有什么实际意义
类型带来的意义
不同类型所占的内存空间不同(单位:字节) eg:int:默认4,溢出就扩容;float:固定8;bool:1;str:变长不同类型对应的操作也是不同的 eg:int/float +-/ 不能用len() #计算字符串类型长度的内联函数 str +但不能-*/ 能用len()动态类型
程序再运行过程中,变量的类型可以改变,见代码
a = 10print(type(a))a = 1.5print(type(a))a = 'hello'print(type(a))a = Trueprint(type(a))
以上代码运行的过程中,a的类型一直再改变,但再python中是支持的
在其他语言,例如C/C++,JAVA中,变量都是静态类型,程序运行中,变量的类型是始终不变的
注:一个编程语言,是否为动态类型,只是取决于运行时,类型是否发生改变,不取决于变量定义的时候是否声明类型。
其实在python中也提供了类型的声明,不多这个类型声明起的作用只是更方便人读代码
a: int = 10b: float = 1.5c: str = 'abc'
其他类型
基本类型先介绍到这,还有list(列表),tuple(元组),dict(字典),自定义类型等后面再介绍
python中的报错
语法错误:python解释器可以识别逻辑错误:运行对应的代码才能发现python报错一般会把问题描述的很详细,这对代码错误的排查很有利
这里其实已经可以基本看到python的设计哲学了:
解决一个问题,只提供一种方案~
Python中的注释
前面也有用到,见下面代码
# 我是注释a = 10 # 我是注释"""文档字符串这是文档字符转起到的作用和注释一样"""print(a)'''文档字符串这是文档字符转起到的作用和注释一样'''
emm,想必根据代码和打印结果我们也可以猜出来python注释的用法了
#其实就是C语言中的 //
""" """和''' '''其实就是C语言中的 /* */
Python中的输入输出
输出:print
# 如果要用print打印"a = 20"->字符串和数字混合a = 20print(f'a = {a}')
单引号前的 f 作用是格式化字符串,在格式化之后,可以使用{ }往字符串中嵌入变量/表达式
输入:input
num = input('请输入一个整数:')print(f'你输入的整数为:{num}')print(type(num))
在这里需要注意的是打印出来num的数据类型是str字符串类型
如果想要用输入的数字进行计算,可以使用强制类型转换 int( )
a = input('输入整数a:')b = input('输入整数b:')a = int(a)b = int(b)print(a + b)
不但可以强转成整型,python中还提供了:
str() -> 整数转字符串类型float() -> 字符串转浮点数类型等等
算数运算符
关于运算符先算乘除后算加减之类的我就不赘述了
+ :加号- : 减号* : 乘号/ : 除号,无法整除会直接计算乘小数并返回赋值** : 乘方运算,eg: x**2,这个代表x的平方// : 地板除法,等价于C语言中的 / ,eg:7 // 2,结果为3% : 和C语言中的%一样,eg:7 % 2,结果为1这里还要注意关于%(取余)运算的一点
在C/C++和JAVA中 -19 % 2 => -1而在python中 -19 % 2 => 1关系运算符(返回bool类型)
< <= > >= != ==
这个关系运算符和C中的一样
要稍微注意一点的就是,python中的字符串类型可以使用关系运算符,比较规则其实就是字典序,谁在字典序的前面谁就小
如果字符串为中文,针对中文进行字符串大小的比较其实是没有意义的
这里还需注意,针对浮点数,使用 == 是存在风险的,所以比较浮点数一般做差看误差范围
逻辑运算符
and 并且,等价于C语言的&&or 或者,等价于C语言的||not 逻辑取反,等价于C语言的!同时python中的逻辑运算符也遵循短路求值
and 的左边为False 右边的条件语句就会放弃执行
or 的左边语句为True 右边的条件语句同样也放弃执行
赋值运算符
# python中支持连续初始化赋值a = b = 20print(a, b)# python中支持下面列表式的初始化及赋值c, d = 10, 20print(c, d)# 在python中支持下面的变量交换c, d = d, cprint(c, d)
符合赋值
+= ,-= ,*= ,**= ,%= ,/= ,//=
a += b相当于a = a + b
a -= b相当于a = a - b
a *= b相当于a = a * b
...以此类推
a = 10a /= 2print(a)
在python中不再支持C语言中的++,--操作
用+=其实就已经很方便了
其他
python中还有一些运算符
身份运算符(is,is not),成员运算符(in,not in)
位运算符(&,|,~,^,<<,>>)等
顺序语句
从上往下按顺序执行的语句
print('111')print('222')print('333')
条件语句(分支语句)
在python中,不再使用{ }来框定代码块,而是单纯使用缩进,同一代码块的缩进级数相同
A.
if expression:
do_somwthing1
do_something2
next_something
choice = input('输入1:')if choice == '1': print('你输入了1') print('这还在if的代码块中')print('结束')
B.
if expression:
do_something1
else:
do_something2
choice = input('输入1:')if choice == '1': print('你输入了1')else: print('输入了别的')print('结束')
C.
if expression1:
do_something1
elif expression2:
do_something2
else:
do_something3
choice = input('输入1或2:')if choice == '1': print('你输入了1')elif choice == '2': print('你输入了2')else: print('输入了别的')print('结束')
注:python中的代码块还支持嵌套,见代码
a = '1'b = '3'if a == '1': if b == '2': print('bbb') print('aaa')print('ccc')
if else elif while for ……这种跟上代码块的部分,都需要用缩进来表示
下方的两份代码缩进都是有问题的(缩进不一致),都会导致编译报错
a = '1'if a == '1':print('bbb') print('aaa')
a = '1'if a == '1': print('bbb') print('aaa')
多级嵌套时,当前语句属于哪个代码块,完全取决于缩进级别
到这里讲完了条件语句,还要提醒大家一点,python中只提供了if else elif ,而C语言中的switch并未在python中提供
空语句
a = '1'if a == '1': # 什么都不做else: print('aaa')
上面这份代码其实是有问题的,在python可以跟语句块的控制语句之后,默认需要跟上至少一条语句,否则编译器会报错,此时如果需要语句什么都不做,可以使用pass语句,见代码
a = '1'if a == '1': passelse: print('aaa')print('hello')
此时的代码才是正确的
循环语句
python中循环语句提供了 while 和 for
A.while循环
while 条件:
循环体
# 代码案例num = 1while num <= 10: print(num) num += 1
B.for循环
for 循环变量 in 可迭代对象
循环体
# 代码案例for i in range(1, 11): print(i)
这里的range是一个内建函数,起到的作用是得到一个“可迭代对象”,其中包含了一系列的整数
range(beg,end) => [beg,end),前闭后开区间
下面是代码案例打印结果
range还提供了第三个参数~表示“步长”,其中步长默认为1
如果你想打印2,4,6,8,10,可以像下面这样写
# 代码案例for i in range(2, 12, 2): print(i)
同时步长还能为负,如果你想打印10到1,可以这样写
# 代码案例for i in range(10, 0, -1): print(i)
控制语句break和continue
python中同样还提供了控制语句continue和break,执行到continue回到条件重新开始语句,执行到break直接跳出语句
# 代码案例for i in range(5, 0, -1): if i == 3: continue print(i)
# 代码案例for i in range(5, 0, -1): if i == 3: break print(i)
函数
函数是什么?简单来说就是一段可以重复使用的代码~
1.函数的定义(分配任务)
def 函数名 (形参列表):
函数体(记得带一层缩进)
return 返回值(更具需求判断是否需要)
2.函数的调用(开始完成任务)
返回值 = 函数名(实参列表)
这里实际参数需要和形参个数匹配
# 代码案例def calcSum(beg, end): theSum = 0 for i in range(beg, end): theSum += i print(theSum)# 这里调用函数calcSum(1, 100)calcSum(300, 400)
这里注意一点,只定义不调用,函数内代码不会执行
python中要求,函数定义写在前面,调用写在后面
这里大家可能也注意到了,python的函数定义时不用声明返回值类型和形参类型,得益于其变量动态类型的特性,下面看一组代码用来体会一下python代码的简单便捷
#代码案例def add(x, y): return x + yprint(add(10, 20))print(add(1.5, 2.5))print(add('hello', ' world'))
python函数的返回值
这里专门放个小标题,就是想讲讲python返回值的特殊性
python中的一个函数,可以返回多个值!!!
# 代码案例def getpoint(): x = 10 y = 20 z = 30 return x, y, z# 使用多元赋值接收a, b, c = getpoint()print(a, b, c)# 如果只想要数值中的一部分,可以使用下划线_占位_, m, _ = getpoint()print(m)
变量的作用域
函数内部的变量名,只在函数内部有效
# 代码案例def getpoint(): x = 10 y = 20 print(x, y)x, y = 20, 30print(f'x = {x}')print(f'y = {y}')getpoint()print(f'x = {x}')print(f'y = {y}')
在函数内部有和函数外部可以使用同名变量,但它们是不同的变量
在外面的变量,全局变量,在整个程序中都有效
在内部的变量,局部变量,在函数内可用
global关键字
既然内部声明的变量无法影响到外部的变量,那如果有函数有这样的需求时怎么办呢,可以使用global关键字,此时,内部变量的改变就可以影响到外面了
# 代码案例def getpoint(): global x x = 10x = 20print(x)getpoint()print(x)
if else while for这些关键字会引入“代码块”,但这不会对变量作用域产生影响。在上述语句代码块内部定义的变量,可以在外部被访问!
只有函数和类会影响作用域
函数递归
简单说,就是一个函数调用自己
eg.写一个函数用于计算n!=> {n*(n-1)*(n-2)....*2*1}
用递归实现的话就是这样的
# 代码案例def factor(n): if n == 1: return 1 return n * factor(n - 1)print(factor(5))
递归的缺点:
1.可能难以理解
2.递归代码容易出现“栈溢出”
3.递归代码一般能转换成等价的循环代码
递归的优点:
代码简洁,尤其处理“问题本身就是通过递归方式定义的”(eg.二叉树)
参数默认值
# 代码案例def add(x, y, debug = False): if debug: print(f'x = {x},y = {y}') return x + y# 这里不传debug默认就会是Falseprint(add(10, 20))# 打印一下换行将两块分开print()print(add(12, 13, True))
这里注意一点:
带有默认值的形参,必须放在形参列表的后面,而不能放在前面/中间!!
关键字参数
想不按照顺序传递参数,这时候可以用关键字参数
# 代码案例def test(x, y): print(f'x = {x}') print(f'y = {y}')# 以这样的形式传参,就可以无视传参顺序了test(x=10, y=20)test(y=20, x=10)
最后,位置传参和关键词传参可以混着用,但要求位置参数在前,关键字参数在后
小结
本来想一口气把基础语法讲完的,没想到内容有些多,就准备分两部分讲了,这部分内容还是比较简单的,在python的下部分,我会介绍列表(list),元组(tuple),字典(dict)和关于文件操作的内容,如果本篇博客对你有帮助的话,还请留个关注点个小赞在走啊---♥,后续博主还会产出更多有意思的内容。