python小白不要怕,小编来保护你~

前言:

小编发现最近私聊我的很多朋友都是零基础的,所以小编整理了一下python基础知识,希望对朋友们有所帮助~

一、运行环境

1、Python解释器

Python解释器就是Python的交互式运行环境,python程序必须有解释器才能够运行,是必备的环境。

python解释器下载地址:https://www.python.org/

版本:python2.7

安装后,一般安装程序给配置好了环境变量,windows下在cmd中输入python回车,如果出现python版本信息,进入命令行,说明配置好了;如果没有,则需要配置环境变量。安装了python解释器之后,便可以运行python程序,可以用命令交互式的,就像在cmd中输入dos命令,也可以直接运行.py结尾的python程序文件。

2、文本编辑器

有了运行环境,但是还得有编码环境,这个很多IDE都对python支持,我的话直接用的notepad文本编辑器。

二、Python基础

1、输入输出

输入输出是最基本的功能,用于用户和计算机进行交互,raw_input和print是在命令行下面最基本的输入和输出。

(1)输出print

用print后面跟上输出的内容,就可以向屏幕上输出指定的内容。

print语句也可以跟上多个输出内容,用逗号“,”隔开,就可以连成一串输出,print会依次打印每个字符串,遇到逗号“,”会输出一个空格。

例如:print 'hello, world'

(2)输入raw_input

Python提供了一个raw_input,可以让用户输入字符串,并存放到一个变量里。需要注意的是raw_input得到得结果是字符串,例如用户输入数值33,通过raw_input得到得变量整形数值33,而是字符串’33’,若是直接用于数值得加减,那么便会报错。

字符串如何转换为相应的变量值?可以通过如下方式:

如果是整形 a = int(str)

如果是浮点型 a = float(str)

若是相应的字符串不能转换成对应的变量类型,那么也会报错。

因此若是要通过输入得到相应的变量类型,那么可以这样做,例如 c = int(raw_input),则输入33,便可以得到值为33的整形变量。

raw_input可以让你显示一个字符串来提示用户:

name = raw_input('please enter your name: ')

2、变量

(1)整数:python的整数包括正数和负数,在程序中的表示方法和数学上的写法一模一样。十六进制用0x前缀。

(2)浮点数:浮点数可以用数学写法,例如3.1415926;对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.63x109就是1.63e9。

(3)字符串:字符串是以''或""括起来的任意文本,比如'abc',"xyz"。如果字符串内部既包含'又包含"可以用转义字符\来标识,例如:'I'm "student"!'(I’m“student”)。

如果字符串里面有很多字符都需要转义,就需要加很多\,为了简化,Python还允许用r''表示''内部的字符串默认不转义。

(4)布尔值:布尔值和布尔代数的表示完全一致,一个布尔值只有True、False两种值。布尔值可以用and、or和not运算。布尔值经常用在条件判断中,而且比较操作符的结果都为布尔值。

(5)空值:空值是Python里一个特殊的值,用None表示。None不能理解为0,因为0是有意义的,而None是一个特殊的空值。

(6)常量: 在python中常量并没有类似C++中const关键字用于表示常量的语法,用以保证某种数据类型的数值在运行过程中不可改变和更改,只能够靠程序员自觉遵守。

在python中,并不需要定义变量类型,如在某个地方引用了变量,该变量在赋值的时候,其赋值的右值是什么类型的数值,在重新赋值之前,该变量就是什么类型的变量。

例如如下:

A = 1

.........

A =“str”

在变量赋值为整数1的时候,此时A的变量类型为整数,一直在A = “str”之前都是整数变量,在A=”str”之后,那么此时A不再是整数变量,而是字符串变量了,若是在之后,A当作整数进行运算,那么会出现错误结果或者运行报错,在python编码中要小心又小心,最好不要将一个变量赋两种不同类型的值,以避免这种错误。

3、list和tuple

(1)list:list是Python内置的一种数据类型是列表。list是一种有序的集合,可以随时添加和删除其中的元素,且集合中的元素可以为不同变量类型的元素,且数据元素的个数为空。classmates = ['Michael', 'Bob', 'Tracy']

len()函数可以获得list元素的个数

用索引来访问list中每一个位置的元素,记得索引是从0开始的,最后一个元素的索引是len(classmates) - 1。如果要取最后一个元素,除了计算索引位置外,还可以用-1做索引,直接获取最后一个元素,若是倒数第二个元素的索引可以是-2,依次类推。

可以往list中追加元素到末尾append方法

要删除list末尾的元素,用pop()方法

要删除指定位置的元素,用pop(i)方法,其中i是索引位置

要把某个元素替换成别的元素,可以直接赋值给对应的索引位置

list中可以嵌套list,组成二维数组甚至三位数组等。

(2)tuple:另一种有序列表叫元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改。classmates = ('Michael', 'Bob', 'Tracy'),只有1个元素的tuple定义时必须加一个逗号,,来消除歧义(避免被识别为函数)。在定义中,tuple在初始化的形式上可以省略括号。

除了通过索引值获取list和tuple中元素的值之外,python还提供了切片(slice)。

  • 通过指定索引范围,对list进行截取。例如list数组L,取前面三个数值,则L[0:3],取前面N个值,则L[0:N],其中截取的list为0到N-1,是索引值0到N的左开右闭的区间。如果第一个索引值是0,那么还可以省略,则为L[:N],当然该种方式也支持负数索引值。
  • list和tuple都可以使用该种方式进行数据的截取,截取后得到的结果依旧是list和tuple,字符串中字符也可以使用这种方式,截取后得到的结果是字符串(可以将字符串看成是单个字符组成的list)。

4、dict和set

(1)dict是Python内置的字典,与C++中的map的功能相似,用于存储使用键-值(key-value),能够通过key快速的检索对应的value值。

初始化

d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}

插入

d['Adam'] = 67

查找key对应的value值

d[key]

如果key存在,就可以返回value值,如果key不存在,那么就会运行报错。在动态检索key的过程中,若是key不存在,运行报错中止程序的话这是很不方便的,因此我们可以在检索前查找是否在该dict中是否存在该key。

两种办法,一是通过in判断key是否存在

'Thomas' in d 存在就返回true,不存在就返回false

二是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value,若是存在则返回对应的value值。

删除

要删除一个key,用pop(key)方法,对应的value也会从dict中删除

dict的key必须是不可变对象,作为key的对象就不能变。在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key。

(2)Set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

要创建一个set,需要提供一个list作为输入集合s = set([1, 2, 3])

添加

通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果

删除

通过remove(key)方法可以删除元素:

5、条件判断和循环

(1)条件判断if语句

if <条件判断1>:

<执行1>

elif <条件判断2>:

<执行2>

elif <条件判断3>:

<执行3>

else:

<执行4>

需要注意的是if else语句的判断为后需要加上冒号’:’,而且判断为true的时候,执行的代码需要缩进。

(2)循环

循环有两种,一种是while循环,一种是for循环。

while循环,只要条件满足,就不断循环,条件不满足时退出循环,其格式与if很像,循环代码执行主体需要缩进,其格式如下,记得while语句之后要加上冒号’:’。

While <条件判断1>:

<执行1>

for循环

for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:

sum = sum + x

一种是for...in循环,依次把list或tuple中的每个元素迭代出来

例如:for x in ...循环就是把每个元素代入变量x,然后执行缩进块的语句。

在使用for对list、tuple和字符串进行迭代时候,可以通过直接迭代或者使用索引值进行间接迭代。因为dict的是通过key-value进行存储的,因此在迭代的时候与list和tuple都不一样,默认情况下,dict迭代的是key。如果要迭代value,可以用for value in d.itervalues(),如果要同时迭代key和value,可以用for k, v in d.iteritems()。

在使用for可以对一些数据类型进行迭代,但若对一些不可迭代的数据迭代就会产生错误。如何判断一个对象是可迭代对象呢?方法是通过collections模块的Iterable类型判断

注:is和==这两种运算符都可以对对象比较,比较是否相等,但是这两种运算符又有差别,其中,is是比较两个引用是否指向了同一个对象(引用比较),==是比较两个对象是否相等。

6、通过下标遍历list

在使用C/C++的时候,通常喜欢使用下表对数组进行遍历。在python中可以通过enumerate函数可以把一个list变成索引-元素对,这样就可以在for循环中同时迭代索引和元素本身。

classmates = ['Michael', 'Bob', 'Tracy']

for i ,name in enumerate(classmates):

print i,name

print classmates[i]

运行结果如下:

0 Michael

Michael

1 Bob

Bob

2 Tracy

Tracy

7、同时引用两个变量遍历

for循环里,同时引用了两个变量,在Python里是很常见的,比如下面的代码:

for x, y in [(1, 1), (2, 4), (3, 9)]:

8、列表生成

列表生成可以通过列表生成式或者列表生成器来进行程序生成。

列表生成式顾名思义,通过自定义表达式,可以快速生成list,可以通过一个list推导出另一个list,表达式一般和for循环写在一起,并通过方括号组成。

例如L=[1,2,3,4,5]的列表,要生成每个元素都是L中元素的平方,则 [x*x for x in L] 此表达式生成的就是一个对L的元素求平方的列表

列表生成式后面可以根据if来进行筛选,将不符合条件的元素刷选调,例如要生成的列表中偶数进行平方操作生成列表,则[x*x for x in ifx%2==0]

列表生成式还可以多层循环,可以生成全排列,例如两层循环,进行全排列,例如:[m + n for m in 'ABC' for n in 'XYZ']

生成器。通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。列表元素可以按照某种算法推算出来,我们可以在循环的过程中不断推算出后续的元素。在Python中,这种一边循环一边计算生成元素的,称为生成器(generator)。

创建一个generator

  • 可以把一个列表生成式的[]改成(),就创建了一个generator。

例如g = (x * x for x in range(10))

  • 可以将在函数定义的时候,如果一个函数定义中包含yield关键字,那么这个函数就不再是一个普通函数,而是一个generator。generator的函数,与普通函数不一样,在每次调用next()的时候执行,遇到yield语句返回,再次执行时从上次返回的yield语句处继续执行。

对于生成器中的元素,我们可以通过generator的next()方法进行遍历,直到遍历玩到最后一个产生异常为止。

在绝大多数情况下,生成器的迭代一般可以用for循环就可以进行迭代遍历了。

在这里,小编也为大家推荐一些入门读物:

1.《Python基础教程》(Beginning Python From Novice to Professional)

2.《Python学习手册》(Learning Python)

3.《Python编程》(Programming Python)

4.《Python Cookbook》

5.《Python程序设计》(Python Programming: An Introduction to Computer Science)

6.《Python编程:从入门到实践》

7.《python入门魔力手册》

8.《笨办法学 Python(第四版)》

9.《深入_Python_3》

10.《Python网络编程基础》

11.《Python语言及其应用(美Lubanovic 2016)》

12.《Python编程入门(第3版)》

13.《Python编程初学者指南》

【这是针对基础朋友的,当然,有需要进阶、web、爬虫、图形图像、数据分析、机器学习等读物推荐的可以私聊小编,加小编好友:2842957735。大家还有想一起交流学习的可以加群:714042473】

你可能感兴趣的:(python小白不要怕,小编来保护你~)