python入门:这篇文章带你直接学会python


Posted in Python onSeptember 14, 2018

初试牛刀
假设你希望学习Python这门语言,却苦于找不到一个简短而全面的入门教程。那么本教程将花费十分钟的时间带你走入Python的大门。本文的内容介于教程(Toturial)和速查手册(CheatSheet)之间,因此只会包含一些基本概念。很显然,如果你希望真正学好一门语言,你还是需要亲自动手实践的。在此,我会假定你已经有了一定的编程基础,因此我会跳过大部分非Python语言的相关内容。本文将高亮显示重要的关键字,以便你可以很容易看到它们。另外需要注意的是,由于本教程篇幅有限,有很多内容我会直接使用代码来说明加以少许注释。

Python的语言特性
Python是一门具有强类型(即变量类型是强制要求的)、动态性、隐式类型(不需要做变量声明)、大小写敏感(var和VAR代表了不同的变量)以及面向对象(一切皆为对象)等特点的编程语言。

获取帮助
你可以很容易的通过Python解释器获取帮助。如果你想知道一个对象(object)是如何工作的,那么你所需要做的就是调用help(<object>)!另外还有一些有用的方法,dir()会显示该对象的所有方法,还有<object>.__doc__会显示其文档:

python入门:这篇文章带你直接学会python

语法
Python中没有强制的语句终止字符,且代码块是通过缩进来指示的。缩进表示一个代码块的开始,逆缩进则表示一个代码块的结束。声明以冒号(:)字符结束,并且开启一个缩进级别。单行注释以井号字符(#)开头,多行注释则以多行字符串的形式出现。赋值(事实上是将对象绑定到名字)通过等号(“=”)实现,双等号(“==”)用于相等判断,”+=”和”-=”用于增加/减少运算(由符号右边的值确定增加/减少的值)。这适用于许多数据类型,包括字符串。你也可以在一行上使用多个变量。例如:

python入门:这篇文章带你直接学会python

数据类型
Python具有列表(list)、元组(tuple)和字典(dictionaries)三种基本的数据结构,而集合(sets)则包含在集合库中(但从Python2.5版本开始正式成为Python内建类型)。列表的特点跟一维数组类似(当然你也可以创建类似多维数组的“列表的列表”),字典则是具有关联关系的数组(通常也叫做哈希表),而元组则是不可变的一维数组(Python中“数组”可以包含任何类型的元素,这样你就可以使用混合元素,例如整数、字符串或是嵌套包含列表、字典或元组)。数组中第一个元素索引值(下标)为0,使用负数索引值能够从后向前访问数组元素,-1表示最后一个元素。数组元素还能指向函数。来看下面的用法:

python入门:这篇文章带你直接学会python

字符串
Python中的字符串使用单引号(‘)或是双引号(“)来进行标示,并且你还能够在通过某一种标示的字符串中使用另外一种标示符(例如 “He said ‘hello'.”)。而多行字符串可以通过三个连续的单引号(”')或是双引号(“””)来进行标示。Python可以通过u”This is a unicode string”这样的语法使用Unicode字符串。如果想通过变量来填充字符串,那么可以使用取模运算符(%)和一个元组。使用方式是在目标字符串中从左至右使用%s来指代变量的位置,或者使用字典来代替,示例如下:

python入门:这篇文章带你直接学会python

流程控制
Python中可以使用if、for和while来实现流程控制。Python中并没有select,取而代之使用if来实现。使用for来枚举列表中的元素。如果希望生成一个由数字组成的列表,则可以使用range(<number>)函数。
函数

函数通过“def”关键字进行声明。可选参数以集合的方式出现在函数声明中并紧跟着必选参数,可选参数可以在函数声明中被赋予一个默认值。已命名的参数需要赋值。函数可以返回一个元组(使用元组拆包可以有效返回多个值)。Lambda函数是由一个单独的语句组成的特殊函数,参数通过引用进行传递,但对于不可变类型(例如元组,整数,字符串等)则不能够被改变。这是因为只传递了该变量的内存地址,并且只有丢弃了旧的对象后,变量才能绑定一个对象,所以不可变类型是被替换而不是改变(译者注:虽然Python传递的参数形式本质上是引用传递,但是会产生值传递的效果)。


Python支持有限的多继承形式。私有变量和方法可以通过添加至少两个前导下划线和最多尾随一个下划线的形式进行声明(如“__spam”,这只是惯例,而不是Python的强制要求)。当然,我们也可以给类的实例取任意名称。
导入

外部库可以使用 import [libname] 关键字来导入。同时,你还可以用 from [libname] import [funcname] 来导入所需要的函数。例如:

python入门:这篇文章带你直接学会python

小结
本教程并未涵盖Python语言的全部内容(甚至连一小部分都称不上)。Python有非常多的库以及很多的功能特点需要学习,所以要想学好Python你必须在此教程之外通过其它方式,例如阅读Dive into Python。我希望这个教程能给你一个很好的入门指导。

Python 相关文章推荐
python实现探测socket和web服务示例
Mar 28 Python
Python中的生成器和yield详细介绍
Jan 09 Python
PyMongo安装使用笔记
Apr 27 Python
Python实现简单拆分PDF文件的方法
Jul 30 Python
Python中正则表达式详解
May 17 Python
Python实现判断字符串中包含某个字符的判断函数示例
Jan 08 Python
Python获取指定文件夹下的文件名的方法
Feb 06 Python
Python网络编程基于多线程实现多用户全双工聊天功能示例
Apr 10 Python
利用Python如何生成便签图片详解
Jul 09 Python
python cv2在验证码识别中应用实例解析
Dec 25 Python
python plt可视化——打印特殊符号和制作图例代码
Apr 17 Python
Python 必须了解的5种高级特征
Sep 10 Python
Python函数any()和all()的用法及区别介绍
Sep 14 #Python
Python连接Redis的基本配置方法
Sep 13 #Python
Python线程下使用锁的技巧分享
Sep 13 #Python
Python利用ORM控制MongoDB(MongoEngine)的步骤全纪录
Sep 13 #Python
python中字符串内置函数的用法总结
Sep 13 #Python
浅析python继承与多重继承
Sep 13 #Python
Python中分支语句与循环语句实例详解
Sep 13 #Python
You might like
PHP 超链接 抓取实现代码
2009/06/29 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十五)
2014/06/30 PHP
php 微信公众平台开发模式实现多客服的实例代码
2016/11/07 PHP
js textarea自动增高并隐藏滚动条
2009/12/16 Javascript
Js中的onblur和onfocus事件应用介绍
2013/08/27 Javascript
基于MVC3方式实现下拉列表联动(JQuery)
2013/09/02 Javascript
通过设置CSS中的position属性来固定层的位置
2015/12/14 Javascript
JavaScript表单验证实例之验证表单项是否为空
2016/01/10 Javascript
JavaScript数据推送Comet技术详解
2016/04/07 Javascript
浅谈对Angular中的生命周期钩子的理解
2017/07/31 Javascript
ionic选择多张图片上传的示例代码
2017/10/10 Javascript
详解Vue组件实现tips的总结
2017/11/01 Javascript
JS中实现隐藏部分姓名或者电话号码的代码
2018/07/17 Javascript
微信小程序下拉刷新PullDownRefresh的使用方法
2018/11/29 Javascript
详解js加减乘除精确计算
2019/03/19 Javascript
解决layui表格内文本超出隐藏的问题
2019/09/12 Javascript
js中Function引用类型常见有用的方法和属性详解
2019/12/11 Javascript
JS forEach跳出循环2种实现方法
2020/06/24 Javascript
Python 功能和特点(新手必学)
2015/12/30 Python
django允许外部访问的实例讲解
2018/05/14 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
python 并发编程 非阻塞IO模型原理解析
2019/08/20 Python
python的移位操作实现详解
2019/08/21 Python
解决Keras 与 Tensorflow 版本之间的兼容性问题
2020/02/07 Python
Python使用tkinter实现小时钟效果
2021/02/22 Python
canvas绘制太极图的实现示例
2020/04/29 HTML / CSS
领先的荷兰线上超市:荷兰之家Holland at Home(支持中文)
2021/01/21 全球购物
工程管理造价应届生求职信
2013/11/13 职场文书
法人授权委托书格式
2014/04/08 职场文书
异地年检委托书范本
2014/09/24 职场文书
办公楼租房协议书范本
2014/11/25 职场文书
经典导游欢迎词
2015/01/26 职场文书
语文教师求职信范文
2015/03/20 职场文书
事业单位工作人员岗前培训心得体会
2016/01/08 职场文书
2016年安全生产先进个人事迹材料
2016/02/29 职场文书
CSS布局之浮动(float)和定位(position)属性的区别
2021/09/25 HTML / CSS