Python 基础入门,莫要白费功夫!

对于一个零基础的想学习python的朋友来说,学习方法很重要, 学习方法不对努力白费 一定要有一个正确的学习线路与方法。

简介

Python 是一种高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。Python 由 Guido van Rossum 于 1989 年底在荷兰国家数学和计算机科学研究所发明,第一个公开发行版发行于 1991 年。

特点

  • 易于学习:Python 有相对较少的关键字,结构简单,和一个明确定义的语法,学习起来更加简单。

  • 易于阅读:Python 代码定义的更清晰。

  • 易于维护:Python 的成功在于它的源代码是相当容易维护的。

  • 一个广泛的标准库:Python 的最大的优势之一是丰富的库,跨平台的,在 UNIX,Windows 和 macOS 兼容很好。

  • 互动模式:互动模式的支持,您可以从终端输入执行代码并获得结果的语言,互动的测试和调试代码片断。

  • 可移植:基于其开放源代码的特性,Python 已经被移植(也就是使其工作)到许多平台。

  • 可扩展:如果你需要一段运行很快的关键代码,或者是想要编写一些不愿开放的算法,你可以使用 C 或 C++ 完成那部分程序,然后从你的 Python 程序中调用。

  • 数据库:Python 提供所有主要的商业数据库的接口。

  • GUI 编程:Python 支持 GUI 可以创建和移植到许多系统调用。

  • 可嵌入:你可以将 Python 嵌入到 C/C++ 程序,让你的程序的用户获得”脚本化”的能力。

  • 面向对象:Python 是强面向对象的语言,程序中任何内容统称为对象,包括数字、字符串、函数等。

结构化要点

将零碎的知识点体系化真的很重要,我把 Python 基础的所有要点结构化成六点:

  1. 编程概论

  2. 数据

  3. 流程

  4. 函数

  5. 对象和类

  6. 高级特征

下面我来一一把它们串联起来。

编程概论:学习任何一种编程语言,我们都需要了解一些概论。类比计算机语言和人类语言,学习语言首先要了解其词汇和语法,再开始讲故事。

  • 词汇包括保留字(keyword)和变量名(variable name)

  • 语法包括缩进、冒号等等

  • 故事可由三种方式来演绎,按顺序讲;按条件讲;重复讲

了解完概论就可以了解所有编程语言中最重要的一环,数据。


数据:数据的重要性不需要多讲,在 Python 中数据可分两大类:

  • 元素型:整数、浮点、布尔、None

  • 容器型:字符串、元组、列表、字典、集合

数据会被命名成变量,变量(词)之间会发现联系(句子),当你试着「用词造句讲故事」的时候,你实际创建了一个流程,而流程需要控制。


流程:类比三种演绎故事的形式,代码也可以按顺序写、按条件写(if)、重复写(while, for),这些都叫做流程控制,当然在运行不出错的时候。如果出错了需要异常处理(try, except)。因此流程控制可细分

  • 按顺序:一句一句写

  • 按条件:用 if 语句

  • 按重复:

    • 用 for 循环 - 当循环次数事先知道

    • 用 while 循环 - 当循环次数事先不知道

  • 要纠正:用 try, except, else, finally 语句

当你想重复使用一组语句时,你需要考虑函数。


函数:Python 定义函数有两种方式:

  1. 用 def 定义普通函数

  2. 用 lambda 定义匿名函数

Python 把函数当成「一等公民」,即可把函数当成变量使用,进而可以定义高阶函数(普通函数和匿名函数都属于低阶函数):

  • 把函数当成输入参数

  • 把函数当成输出结果

介绍完数据和函数后,我们可得出

  • 如果只处理数据,将其存储在列表,字典或其他数据中

  • 如果只处理行为,而没有存储数据,则使用函数更合适

如果同时要处理到数据和行为呢?考虑对象和类。


对象和类:对象是既具有数据又具有行为的实例,而类是对象的描述。变量和函数是零散的,而对象将它们集合起来,

  • 在对象里也有变量,用来存储数据,这时变量又称字段(fields) 

  • 在对象里也有函数,用来操作数据,这时函数又称方法(methods)

字段和方法统称为类的属性(attributes)。

基于对象编程叫做「面向对象编程」,里面的知识点包括:实例变量、类变量、实例方法、类方法、静态方法、继承、多态、魔法方法、属性装饰器等。


高级特征:这是都是些锦上添花的东西,包括格式化字符串、正则表达式、解析表达式、生成器、迭代器和装饰器等等。一句话来总结这些知识点:

  • 格式化字符串:f-string,用法 f' {v1} {v2} ... {vn} .'

  • 正则表达式:r-string,用法 re.function(pattern, text)

  • 解析表达式:列表、字典、集合解析式,用 [], {}, ()

  • 生成器:生成器是迭代器,但反之不是

    • 生成函数 + yield

    • 生成表达式 + ()

  • 迭代器:

    • iter(可迭代对象) --> 迭代器

    • 迭代器是可迭代对象

  • 装饰器:用 @decorator_function

当把整套 Python 基础知识的体系搭建出来后,还需要对内部的每个知识点细节进行深挖。学海无涯,我们先来了解一些Python中最基本的19个语法内容。

01 中文编码

很多同学在打开数据时会遇上乱码问题,其原因是字符集的编码问题。Linux和Mac默认的编码集是UTF8,而Windows则是ASCII。如果数据编码的字符集,和你使用Python进行处理时所用的字符集不同,则会出现乱码问题。

另外,我个人的习惯是在Python代码的头部加入以下内容,其中第二行声明了使用UTF8字符集。

#!/usr/bin/env python# coding:utf8

02 变量

Python中的变量可以看作是一个个容器,里面存放着我们需要使用到的值。

Python对变量名的要求和其他语言一样:可以包括英文、数字以及下划线,但不能以数字开头,区分大小写。当然我推荐,变量名用纯英文就很好,并且取一些有意义的名称,便于自己理解每个变量的作用。

Python是一门弱类型的语言,在使用变量时无需声明其类型。Python中的变量包括以下几类:数值、字符串、列表、元组、字典。

03 数值

数值包括整型和浮点型,分别对应整数和浮点数,后者精度更高。

# 整型a = 1# 浮点型b = 2.1print a, b

04 字符串

字符串也就是我们经常接触到的文本,可以往里面放任意长度的内容,用单引号或双引号括起来。应当注意,中文以及中文符号只能出现在字符串內,如果在下面第三行中使用了中文输入法的逗号  ,Python将报错。

c = 'Hello'd = '你好'print c, d

使用 + 可以拼接两个字符串。

print c + d

使用 len() 可以得到字符串的长度。

print len('Hello World')

使用切片可以访问字符串中的某个字符或某个片段。

# 位置下标从0开始c = 'Hello World'# 打印结果为H,下标为0表示第一个字符print c[0]
# 打印结果为d,下标为负数表示从后往前数# 所以-1表示倒数第一个字符print c[-1]
# 使用:返回一个片段,冒号前后分别为开始下标和结束下标# 包括开始下标,但不包括结束下标
# 因此c[1:5]表示,返回下标从1到4的片段,即第二个到第五个字符print c[1:5]
# 冒号前后的下标同样可以使用负数
# 或者不提供,表示从最左端开始或一直到最右端print c[1:-1], c[:5], c[3:]

05 列表

列表好比一条队伍,里面依次存放着多个变量。列表和字符串类似,但字符串中的每个元素都是字符,而列表中的每个元素可以是任意类型的变量。

# 使用[]定义一个空列表,使用append()向列表尾部添加一个元素
# 如果要添加到首部,就用prepend()好了a = []a.append(1)a.append(2.1)a.append('Hello')print a

使用 len() 可以获得列表的长度。

print len(a)

列表元素的按下标访问和赋值等操作,和字符串都是类似的。

print a[1], a[-1]a[1] = 100print a

使用 del 删除列表中的某个元素。

del a[0]print a

06 元组

元组和列表类似,唯一的不同是元组中的元素在初始化之后不能再更改,因此可以理解成一个只读的变量。

# 使用()定义一个元组a = (1, 2.1, 'Hello')# 尝试修改元组中的元素会报错a[0] = 100

07 字典

字典是一种极为重要的变量类型,使用一个key来访问相应的value,即一种键值对的数据形式。

# 使用{}定义一个字典a = {}# 使用key来赋值valuea['k1'] = 1a['k2'] = 2.1a['k3'] = 'Hello'

所以能够总结出字典和列表的不同。列表中的元素是有序对等的,所以是用下标来赋值和访问,而字典中的元素是无序的,所以是用key来操作相应的value。

# 也可以在定义字典和列表的同时进行赋值li = [1, 2.1, 'Hello']di = {'k1': 1, 'k2': 2.1, 'k3': 'Hello'}

使用 has_key() 判断字典中是否有某个key。

print di.has_key('k4')

如果访问不存在的key,Python将会报错。在赋值的时候,如果key已经存在,则会用新的value覆盖已有的value。

08 注释

被注释的代码将不会运行,可以看作是写给自己和其他程序猿阅读的一些笔记和说明,提高代码可读性。

# 这里是单行注释'''这里是很多行注释'''

在Sublime中,选中需要注释的内容,按Ctrl+/即可完成注释。

09 保留字符

在Python中,有一些字符串具有某些特定功能,如 import 、 class 等。我们在选择变量名时,应注意避开这些保留字符。

# 以下变量赋值将报错import = 1

10 行和缩进

在Python中,代码块的边界不是通过大括号等符号进行显式划分,而是通过行的缩进实现的。连续相同缩进水平的代码处于同一个代码块,在使用 for 、 while 、 if 、 try 等语法时需要注意每行代码的缩进。

11 运算符

运算符的作用是根据已有的变量生成新的变量,主要有以下几种:

  • 算术运算符:+,-,*,/,%,即加、减、乘、除、取余

  • 比较运算符:==,!=,>,<,>=,<=,即等于、不等于、大于、小于、大于等于、小于等于

  • 赋值运算符:=,+=,-=,*=,/=,%=,即赋值、加赋值、减赋值、乘赋值、除赋值、取余赋值

  • 逻辑运算符:and,or,not,即与、或、非

a = 1b = 2print a + bprint a == b# 等价于 a = a + 3a += 3print ac = Trued = Falseprint c and d

12 条件

在写代码的时候,往往需要根据某些条件进行判断,并根据判断结果执行不同的分支代码。

a = 1# 单个条件if a == 1:    print 11111# 处理条件不成立的分支if 
a == 2:    print 22222else:    print 33333# 多个条件,加多少个都可以if 
a == 1:    print 11111elif a == 2:    print 22222else:    print 33333

需要注意的是,但凡出现了 if 和 elif ,就需要加上相应的条件判断,并且注意代码的缩进。在Sublime中输入 if 会出现相应的提示,可以方便地补全代码,在换行时光标也会自动跳到合适的缩进处。

13 循环

如果需要打印从1到100的100个数,肯定不会傻傻地写100行print代码,而是会用循环来处理类似的重复性工作。

14 while 循环

while 循环的思想是,只要某一条件成立,就不断执行循环体里的代码,直到条件不再成立。

flag = 1while flag < 10:    print flag    
# 一定要记得在循环体里修改条件变量    
# 否则可能导致死循环    flag += 1

15 for 循环

for 循环的循环次数一般是事先预知的,将一个标志变量从某个起始值迭代到某个终止值后即结束。

# x从0开始,一直到9结束for x in xrange(0, 10):    print x

可以用 for 循环方便地遍历列表和字典。

li = [1, 2.1, 'Hello']dict = {'k1': 1, 'k2': 2.1, 'k3': 'Hello'}
# 遍历列表,这里的item只是一个临时变量,取别的名称也行for item in li:    print item
# 遍历字典的全部key,这里的key也只是一个临时变量,名称不重要for key in dict.keys():    print key
# 遍历字典的全部value,这里的value也只是一个临时变量,名称不重要for value in dict.values():    print value# 同时遍历key和valuefor key, value in dict.items():    print key, value

16 循环控制

循环控制主要包括三种: pass 、 continue 、 break 。

pass 表示什么也不做,只是占一行代码的位置;continue 表示立即退出本轮循环,继续执行后续轮循环;break 表示立即推出循环,后续循环也不再执行。

for x in xrange(0, 10):    if x == 5:        pass    else:        print xfor x in xrange(0, 10):    if x == 5:        continue    print xfor x in xrange(0, 10):    if x == 5:        break    print x

17 时间

在处理数据时,很多地方都会涉及到时间,例如数据产生的时间。先介绍一下时间戳的概念,时间戳指的是从1970年1月1日0时0分0秒开始,到某一时刻所经历的秒数,可以是整数或者小数,后者的精度更高。

为什么需要时间戳这样的一个概念?因为对于同一个时刻,不同人的描述可能不同,毕竟文本的形式千变万化,而时间戳使得时间的表达得到了统一,每个时刻只能用唯一的整数或浮点数来表示,同时也便于计算时间差这样的处理。

# 来看一下当前时刻的时间戳吧import timet = time.time()print t, type(t)

关于时间戳,最常用的处理便是时间戳和时间文本之间的转换,例如将 2016年10月1日 10时0分0秒 转为时间戳。

import time# 时间文本转时间戳,精确到秒a = '2016-10-01 10:00:00'a = int(time.mktime(time.strptime(a,'%Y-%m-%d %H:%M:%S')))print a# 时间戳转时间文本b = int(time.time())b = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(b))print b

其中, %Y 、 %m 等都是时间字段,前者表示四位的年份,后者表示两位的月份。

文件

文件操作包括向文件中写内容,以及从文件中读内容,使用 open() 打开一个文件。

# 写文件# 重新写模式,打开文件时会将文件内容清空fw = open('data.txt', 'w')# 追加写模式,打开文件后保留原始内容,继续写入for x in xrange(0, 10):    # 将整数转成文本再写入    fw.write(str(x))    # 也可以每次写入之后换行,
为转义字符,表示换行    # fw.write(str(x) + '
')fw.close()# 读文件fr = open('data.txt', 'r')# 一行一行地读,line只是个临时变量,取别的名称也行for line in fr:    print line    # 如果每行后面有换行,可以将换行符去掉,使内容更紧凑    # strip()可以去掉字符串两端的空白字符    # print line.strip()fr.close()

18 异常

Python代码中可能会出现一些可以预知的问题,例如字典访问的key不存在。如果不加处理,发生问题的时候Python便会报错并退出,可能之前跑了很久又要重头再来。因此,我们需要对可能出现的异常进行捕捉和处理。异常的结构由 try 、 except 、 else 、 finally 四部分组成。

try:    # 尝试执行这些代码    print 1 / 0except Exception, e:    # 如果出现异常就进行处理    # e为出现的异常类型    print eelse:    # try里的代码没有出错    # 可以执行后续工作了    print '没有出错'finally:    # 无论是否出错,都会执行的代码    print '一定会执行'

19 函数

函数的作用是代码模块化,将可重用的代码封装成一个函数,这样在需要使用的时候就只需调用写好的函数即可,而不用重新写一遍代码。

函数的使用包括两个部分,函数的定义和函数的调用。除此之外,函数可以有一个或多个参数,参数之间以逗号分开,为函数的功能提供更多的灵活性。

# 定义函数def hello(name1, name2):    print 'Hello ' + name1 + ' ' + name2# 调用函数hello('Python', 'JavaScript')

Python教程推荐:

Python3-菜鸟教程  https://dwz.cn/2nJnWkrp

Python练手项目合集  https://dwz.cn/cpM0jua5

△ Python基础知识框架

另外,Python中两个非常重要的库Numpy和Pandas也是需要掌握的,我们的很多数据处理及分析方法就源于其中。

如果把Python比作是我们的房子,为我们提供基础的框架,那么Numpy和Pandas就是房子里的家具和电器,为我们入住提供各种功能。

当然,即便只是这两个库,官方文档的内容也是非常多的,建议先掌握最常用的一些方法,这样你可以决大部分的实际问题,若后续遇到问题可以有针对性地去查询文档。

高效的学习是什么?就是按一定的路径顺序循序渐进,你会知道每个部分需要完成的目标是什么,需要学习哪些知识点,哪些知识是暂时不必要的。

然后每学习一个部分,你就能够有一些实际的成果输出,有正向的反馈和成就感,你才会愿意花更多的时间投入进去。以解决问题为目标,效率自然不会低。

关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

在这里插入图片描述

二、Python必备开发工具

 三、精品Python学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

四、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

五、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

六、Python练习题

检查学习结果。

七、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 最后祝大家天天进步!!

上面这份完整版的Python全套学习资料已经上传至CSDN官方,朋友如果需要可以直接微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值