Python的热度不言而喻,机器学习、数据分析的首选语言都是Python,想要学习Python的小伙伴也不少,我以前也没有认真用过Python,因此也想体验一下它的魅力,索性花了两天集中看了一下它的基本语法,组织了这篇笔记,一是增强一下本身的记忆和理解,二是能够分享给共同窗习的小伙伴。这篇笔记主要是Python的基本语法,算是入个门,后面能够边用边增强。python
在python中,输入用 input( ),输出用 print( )。ios
简单的例子:c++
两点注意:app
Input()接收的输入数据都认为是字符串,如作其它类型使用,需转换。机器学习
Print()能够作格式化输出,同C相似,%d(整型)%s(字符串)%f(浮点型),如搞不清,直接都用%s也能够,它会把任何数据类型转换为字符串。函数
#用python计算圆的面积; #定义一个变量接收输入的圆半径 r=input("请输入圆半径:") #定义一个变量存放计算出的圆面积 #特别注意:python3针对输入统一都认为是字符串型 #因此在计算时要将其转换为整形数,格式:int(x) s=3.14*int(r)*int(r) #输出计算出的圆面积s print("圆面积s=",s) #也能够直接在输出print里计算圆面积 print("直接在print里计算面积:",3.14*int(r)*int(r)) #利用占位符实现格式化输入,这里和C语言是相似的 print("输入的圆半径是%s,圆面积是%f" %(r,3.14*int(r)*int(r)))
运行结果: 请输入圆半径:4 圆面积s= 50.24 直接在print里计算面积:50.24 输入的圆半径是4,圆面积是50.240000
在c++中,咱们要使用变量,就须要先声明一个数据类型,不一样的数据类型长度不一样,可以存储的值范围也不一样,也就意味着不一样的数据类型不能混淆使用。下面的代码是C++中的变量。学习
#include<iostream> #include<string> #include <limits> using namespace std; int main() { int a=10; //整型:4个字节 char b='x'; //字符型:1个字节 float c=3.14; //单精度浮点:4个字节,7个数字 cout<<"int a="<<a<<"\t长度是"<<sizeof(int)<<endl <<"char b="<<b<<"\t长度是"<<sizeof(char)<<endl <<"float c="<<c<<"\t长度是"<<sizeof(float)<<endl; }
运行结果: int a=10 长度是4 char b=x 长度是1 float c=3.14 长度是4
在Python中,whatever,一切都是那么的随意,充满着自由的气息。spa
#定义一个变量a,给它一个整形值27 a=27 print(a) #再将a的值变为一个浮点数,3.1415927 a=3.1415927 print(a) #再将a的值变为一个字符串,J_ZHANG a="J_ZHANG" print(a)
运行结果: 27 3.1415927 J_ZHANG
能够看出,变量a是什么数据类型,who cares,给它赋的值是什么类型,它就是什么类型。设计
一个栗子,有助理解:code
a = 123 #执行这句话,python干了两件事 #一是在内存中建了个123的整数 #二是在内存中建了个变量a,而后将a指向刚建的整数123 b = a #执行这句话,python建了个变量b,并指向a所指向的123 a = 'ZNN' #这句话python建了个字符串ZNN,并将a指向了新建的ZMM #注意:b没有改变哟,它仍是指向a原来指向的那个123 print("执行输出:a=",a,";b=",b) #print(b)
运行结果: 执行输出:a= ZNN ;b= 123
两个小概念:
🔗动态语言:像Python这样,变量使用以前不须要类型声明,变量的类型就是被赋值的那个值的类型,动态语言是在运行时肯定数据类型的语言。
🔗静态语言:在定义变量时必须指定变量类型,且在赋值时类型要相匹配,不然会出现运行时类型错误。如C/C++/JAVA等语言。
值可变,是一种有序列表,可经过索引访问列表元素,索引从0开始,也可从-1开始进行反向访问。可随意添加、修改、删除其中的元素,元素数据类型能够不一样,可嵌套使用造成多维列表。简直不要太强大了!
#定义一个list变量stuName,list元素可为不一样类型 stuName=['FF','NN','ZZ',1999,'HH','XY'] #获取list的长度,len() print('stuName的元素个数:',len(stuName)) print(stuName) #访问list元素,索引是从0开始,反向访问从-1开始,-1是最后一个元素索引 print('第一个元素是:%s,倒数第二个元素是:%s' %(stuName[0],stuName[-2])) #增、删、改 stuName.append('J_ZHANG')#在末尾追加一个元素 print(stuName) stuName.insert(0,2009)#在指定位置插入元素 print(stuName) stuName.pop()#删除最后一个元素 print(stuName) stuName.pop(4)#删除第五个元素 print(stuName) stuName[3]='J_ZHANG'#修改索引为3的元素 print(stuName) stuInfo=[stuName,[10,20,30]]#嵌套使用 print(stuInfo) print(stuInfo[0][3])#二维List的访问方式
运行结果: stuName的元素个数:6 ['FF', 'NN', 'ZZ', 1999, 'HH', 'XY'] 第一个元素是:FF,倒数第二个元素是:HH ['FF', 'NN', 'ZZ', 1999, 'HH', 'XY', 'J_ZHANG'] [2009, 'FF', 'NN', 'ZZ', 1999, 'HH', 'XY', 'J_ZHANG'] [2009, 'FF', 'NN', 'ZZ', 1999, 'HH', 'XY'] [2009, 'FF', 'NN', 'ZZ', 'HH', 'XY'] [2009, 'FF', 'NN', 'J_ZHANG', 'HH', 'XY'] [[2009, 'FF', 'NN', 'J_ZHANG', 'HH', 'XY'], [10, 20, 30]] J_ZHANG
值不可变,与List相似,元素可为任意类型,但其一旦定义了,里面的值是不可改变的,没有append()、 insert()这些方法,但若是Tuple里面有个元素为List类型,则这个List里的值是能够改变的。
#定义一个Tuple变量stuName,元素可为不一样类型,但值不可改变 stuName=('FF','NN','ZZ',1999,'HH','XY') print(stuName) print(stuName[0],stuName[-1])#Tuple元素访问与List相似 #stuName[2]='J_ZHANG' #会报错,值不可变 stuInfo=('aa','bb',[10,20,'string'])#Tuple里面包含List类型元素 print(stuInfo) stuInfo[2][2]=30#包含的List里的元素是能够修改的 print(stuInfo)
运行结果: ('FF', 'NN', 'ZZ', 1999, 'HH', 'XY') FF XY ('aa', 'bb', [10, 20, 'string']) ('aa', 'bb', [10, 20, 30])
字典是以键值对(key-value)的方式存储,该方式键与值一一对应,能够快速的根据key找到value,查询速度快。注意,键(key)不可变,值(value)可变。简单理解,学生的姓名(key)和成绩(value)用字典存放,是一一对应的,找到学生的姓名,便可立刻知道他的成绩了,查找速度快。
#定义一个Dict变量stuScore,姓名(key)与成绩(value)一一对应 stuScore={'FF':80,'NN':90,'ZZ':100} stuScore['HH']=70#在后面添加一个键值对 print(stuScore) print(stuScore['HH'])#获取键所对应的值 stuScore.pop('HH')#删除指定的键值对 stuScore['ZZ']=89#修改键ZZ的值 print(stuScore) print(stuScore.keys())#获取全部键 print(stuScore.values())#获取全部值 print(stuScore.items())#按组打印
运行结果: {'FF': 80, 'NN': 90, 'ZZ': 100, 'HH': 70} 70 {'FF': 80, 'NN': 90, 'ZZ': 89} dict_keys(['FF', 'NN', 'ZZ']) dict_values([80, 90, 89]) dict_items([('FF', 80), ('NN', 90), ('ZZ', 89)])
一个简单的应用,统计一组数据中不一样性别的数量,有助理解字典。
#定义一个Dict变量stuInfo,姓名(key)与性别(value) stuInfo={'FF':'女','NN':'女','ZZ':'男'} #下面统计 stuInfo 里面'男'、'女'的数量 stuXBTJ={}#定义一个空字典用于存放统计结果 for xb in stuInfo.values():#遍历 if xb in stuXBTJ:#若是该性别已存在,则加1 stuXBTJ[xb]= stuXBTJ[xb] + 1 else:#不然,该性别数量初始化为1 stuXBTJ[xb]=1 print(stuXBTJ)#打印结果
运行结果: {'女': 2, '男': 1}
集合是无序的,也没法经过数字进行索引。此外,集合中的元素不能重复。集合能够进行数学意义上的交集、并集等计算。建立set,须要一个list做为输入集合。
#利用一个List建立一个Set集合 stu=['FF','ZZ','NN','JJ','ZZ','FF'] s=set(stu)#建立集合s print(s)#打印s发现重复项已被自动过滤 s.add(27)#添加一项 s.remove('JJ')#删除一项 print(s) s1=set([1,2,3,4,5]) s2=set([4,5,6,7,8]) print('交集',s1 & s2)#计算两个集合的交集 print('并集',s1 | s2)#计算两个集合的并集 print('差集',s1 - s2)#计算两个集合的差集
运行结果: {'NN', 'ZZ', 'JJ', 'FF'} {'NN', 'ZZ', 27, 'FF'} 交集 {4, 5} 并集 {1, 2, 3, 4, 5, 6, 7, 8} 差集 {1, 2, 3}
选择与循环是程序设计的两种主要结构,Python的选择与循环与其它语言的写法截然不同,习惯C/C++/C#的写法开始会有些不适应的。(注意:Python里没有大括号,它是靠缩进来区分代码段的。)
选择:if else & if elif else
score=78 if score>=60: print('及格!')#执行 print('OK !')#执行,没有大括号,用缩进 else: print('不及格!') if score>=80: print('优秀!') elif score>=70: print('良好!')#执行 elif score>=60: print('及格!') else: print('差!') #if...elif是从上到下判断,遇到true即执行,其他忽略。
运行结果:
及格!
OK !
良好!
循环:for & whele
#for循环实现list遍历 stuName=('FF','NN','ZZ') for name in stuName: print(name) stuInfo=[['FF','NN'],[22,27]] for i in stuInfo:#Ffor循环嵌套使用 for j in i: print(j) sum=0 n=0 while n<=10:#while循环的使用 sum=sum+n n=n+1 print(sum)
运行结果: FF NN ZZ FF NN 22 27 55
break和continue的用法与C++一致。
break:提早结束循环。
continue:结束本轮循环,直接开始下一轮循环。
读文件:同C相似,Python内置了读文件的函数open(),使用注意事项:
文件打开用完要关闭,open()和close()配对使用。
避免文件打开失败或忘记关闭等形成的错误,使用with…as…操做文件。
#使用open()函数读文件,文件位置:D:\test.txt f=open("D:\\test.txt","r")#打开文件,第二个参数“r”表示读 fn=f.read() print(fn) f.close()#完成操做后必需要关闭文件 #文件打开用完就要关闭,但不排除一通操做后忘了关闭文件, #同时还存在文件打开失败的状况,使用with…as…操做文件更可靠,更简洁。 with open("D:\\test.txt","r") as f: fn=f.read() print(fn)
运行结果: python file_IO FF 22 NN 09 ZZ 26 python file_IO FF 22 NN 09 ZZ 26
写文件:写文件和读文件是同样的,先open,而后write,最后close,open时第二个参数是“w”。
写文件时,若是目标位置没有文件,python会建立文件。
若是目标位置有文件,参数“w”就会覆盖写入,追加写入可用参数“a”。
能够反复调用write()写数据,但若是最后忘记close()文件,后果多是数据丢失,保险起见,仍是使用with…as…更靠谱。
#在D盘建立一个新文件test_new.txt,而后写入内容, f=open("D:\\test_new.txt","w") f.write("J_ZHANG") f.close() #再次写入就会覆盖原内容 with open("D:\\test_new.txt","w") as f: f.write("覆盖了吗?") f.write("\n")#换一下行 #使用参数“a”实现追加写入 with open("D:\\test_new.txt","a") as f: f.write("J_ZHANG追加写入的。") #打印出来看一下 with open("D:\\test_new.txt","r") as f: print(f.read())
运行结果:
覆盖了吗?
J_ZHANG追加写入的。
Python用def关键字定义一个函数,定义时需肯定函数名与参数,函数能够有多个返回值,但如函数没有return,则默认还回none。因python变量为动态类型,如函数对参数有类型要求,需在函数体内进行类型检查。
#使用def定义一个函数:求圆面积 def cir_area(r): if not isinstance(r,(int,float)):#参数类型检查,r为整型或浮点型 raise TypeError("参数r类型错误!") if r<=0: return 0#判断若是半径小于等于0则返回0 else: return 3.14*r*r #调用函数 s=cir_area(4)#半径为4的圆面积 print(s)
运行结果: 50.24
OK,就酱紫!暂时先到这儿。
-------------------------- END --------------------------