python学习-基础知识-1

1、计算机历史

计算机使用高低电压的两种状态来描述信息。计算机可以理解的只有二进制数据即010100011....,1个比特位可以表示的状态只有2种,n个比特位可以表示的状态有2的n次方种。

所以如果想要描述天气状态:天晴、下雨、刮风、下雪、霜冻,则需要使用3个比特位。

2、编程语言历史

计算机只能理解二进制数据,二进制数据中蕴含了很多指令、操作、数据,计算机通过cpu直接运行二进制代码执行不同的功能,二进制代码被称为机器语言。

但是机器语言(二进制代码)对于人类而言可读性太差、编写太困难,所以人类需要使用适合自身的语言来编程以操作计算机。

一开始,人类将机器语言中的代码进行分类、标记,把蕴含操作行为、蕴含数据的二进制代码使用英语单词标记,形成了汇编语言。汇编语言的模式是:操作行为+被操作数。

操作行为和被操作数都使用英语单词代替了一串010101的二进制代码,这样人类只需要编写汇编语言,再将汇编语言通过之前的映射关系转换成二进制即可。

通过汇编语言,人类即可以方便的编写代码,又可以通过转化得到对应的二进制代码让计算机运行。

但是,汇编语言依然可读性较差、编写也不是非常的方便,要实现一个简单的功能需要非常多的汇编代码,代码冗余性依然很高。

于是,人类模仿汇编和二进制的对应关系,将高级语言和汇编又对应起来,这时候人类就只需要编写高级语言,再通过编译器将高级语言转换成汇编语言或者直接转换成二进制代码。

高级语言的代码非常接近人类的英语,所以使用起来很方便。

因语法规则、语义的不同,高级语言分为很多种,如:python,java、c、c++、JavaScript,ruby等等。

3、编译型高级语言/解释性高级语言

高级语言接近人类英语,编写的代码可读性也很强,但是计算机是无法直接理解和执行源代码的,因为计算机只认识二进制代码,所以不论是哪一种高级语言,都需要将源代码转换成二进制代码后才能被计算机执行。

在转换过程中,有2种不同的情况:

1、编译型

编译型高级语言,在程序执行之前,需要提前将源代码通过编译器转换成目标文件(二进制代码),然后计算机直接执行目标文件。

优点:计算机执行效率高、速度快

缺点:

如果程序需要修改,必须修改源代码并再次编译,修改不方便

一旦编译完成,目标文件就只能在当前操作系统和cpu架构上运行,无法在其他平台使用,除非重新编译

举例:c、c++、c#

2、解释型

解释型高级语言,由解释器实时读取源代码并编译成二级制代码交由计算机执行。

优点:

程序的修改直接操作源文件即可,修改方便

只要计算机安装了对应平台的解释器,源代码就可以被执行,即一份源代码可以在不同平台运行,平台兼容性好

缺点:

因为需要实时编译,所以运行效率低、速度较慢

需要一个匹配版本和平台的解释器与源代码共同工作

举例:python、java、ruby

4、python版本

python有2个相互不兼容的大版本,版本2最高是2.7,版本3截止20180603最高是3.6.5。版本2官方宣布将会维护到2020年,建议现在选择版本3编码。

5、python解释器

解释器也是一种程序,功能是将python源代码翻译成机器语言。解释器可以使用多种语言编写,有如下几种:

cpython,官方发布的解释器,使用c语言编写

ipython,在cpython基础上套了一个壳,提高用户交互性

pypy,据说使用jit技术动态实时编译使得代码运行速度更快,但是目前暂不成熟

jpython和icronpython,使用java和.net编写,一般不使用

6、python文件执行

两种方式执行python文件,一种是启动解释器并将python源文件作为参数,解释器读取文件中代码。一种是启动解释器,在交互环境编写代码执行。

7、变量

1、变量存在的原因

用于保存阶段性计算的结果,同时变量用于描述程序中的一些数据,良好的变量命名和使用会增加代码的可读性。

2、变量命名规范

变量名可以是数字、字母、下划线的任意组合,注意:不可使用除了下划线之外的特殊字符

变量名开头不能是数字

变量名不能和python预定义的关键字重名

注意:python竟然可以使用中文作为变量名!

3、变量定义语法

age = 26

定义一个变量,它的名字是age,此变量指向内存中的一个对象,此对象值是26

8、常量

常量的命名规范和变量一样,不过常量的命名约定俗成的是全大写。

常量用于保存基本不变的数据,python没有提供类似c语言的const关键字来强制规定常量的不可变性,所以python中的常量是约定俗成的不可变。

9、python安装

www.python.org官网下载最新版本3.6.5,根据电脑配置选择32或者64位,安装的时候选择add to path并自定义安装位置和其他高级选项,安装完成可以直接shell进入python解释器。

10、输入/输出

python中通过input函数提供shell输入,通过print函数提供shell打印。

input函数会阻塞程序执行直到获取shell输入值

11、注释

不论哪一种高级语言,我们在编码的时候都是将脑海中的思路、信息、步骤简化成实际的代码。将大脑中的信息转换成实际代码的时候,会有很大的信息量丢失,即代码所表达的信息量是很少的。

所以单独的代码无法还原编码时的全部信息量,此时我们就需要使用注释来弥补代码缺失的信息量。优秀的注释+代码可以提供很高的可读性,也方便后续代码使用和维护。

注释有几个需要遵守的规范:

1、注释的内容应该保持与代码的强一致性,注释应该精简、准确的表达代码的含义、编码背景等

2、可以使用中文或者英文

3、注意注释的使用量,在适当且必要的地方使用注释,如:重要流程节点、复杂代码块解释等

12、数据类型

计算机只认识二进制,对于计算机而言,数据没有类别,全部都是010101010...

但是对于人类而言,人类世界中的数据、信息是五花八门的,我们编码的过程其实就是在计算机世界中对现实世界进行建模的过程,所以我们需要对人类世界的数据划分类别。

基础的数据类型有:数字(整数+小数)、字符串、布尔值

我们使用int来表示整数类型、float表示小数类型

我们使用str表示字符串类型

我们使用bool表示布尔值类型

数字类型用于计算、字符串类型用于表示信息、布尔类型用于判断

13、字符串格式化输出

所谓格式化输出,其实就是在编码过程中定义展示模板,在模板中通过占位符代表后续有对应数据填充在此。

占位符:

%d 整数类型

%f 小数类型

%s 字符串类型(%s是万能匹配,即任意数据类型都可以填充到%s占位符中)

%r 原格式(将数据的原始格式存放到%r占位符中,如字符串的原格式就包含引号)

14、运算符

算数运算符

+  -  *  /  (注意,/ 除法运算符得到的商可以是小数,即5/2 = 2.5)

//  %  (地板除得到的结果是商的整数部分,如5//2 = 2。取模得到的结果是未整除的结果,如5%2 = 1,对2取模可以判断奇偶。)

**  (幂运算,5**2 = 25)

比较运算符

==  >  <  >=  <=  !=  (==表示的是两边对象的值是否相等,python3中使用!=表示不等于,不再使用<>)

赋值运算符

= (赋值)

+=  -=  *=  /=

//=  %=  **=

(在原有值的基础上做运算,并赋值给原有变量,如a = 5, a %= 2,此时a = 1)

逻辑运算符

and  or  no  (逻辑判断会使用短路判断,所以:使用and的时候,概率小的放前面。使用or的时候,概率大的放前面。)

15、流程控制-分支

程序默认是自上而下没有分支的执行代码。很多时候我们需要通过判断程序运行中间的某一种状态、情况、值,来决策程序下一步该执行哪些代码。

通过分支提供多条执行路线,分支有双分支、多分支。

之所以可以划分多种分支是因为可能出现多种不同条件,而这些条件的概率和应该为1。

分支需要特别注意条件判断的逻辑性,多种条件只会执行其中一个条件,条件之间是相互对立的。

通过if  elif  elif  else来提供多分支,通过条件的布尔值结果判断条件是否成立。

注意:条件判断应该把概率大的放在前面,概率小的放后面,对于无法明确具体判断条件的可以放在else统一匹配。另外,判断input的返回值的时候注意,input返回值一定是字符串。

16、流程控制-循环-while

while关键字后面的语义是:判断条件是否成立?成立的话执行一次循环体然后再次判断条件是否成立。不成立的话跳过此循环体执行后续代码。

因为循环代码有导致死循环的风险,所以任何一个循环定义,都需要预先设计循环跳出条件。循环可以在循环体中通过break跳出,或者通过while条件判断不成立跳过。(当然,也可以在循环体中exit)

通过continue可以提前结束当前循环,直接开始下一次的循环while判断,注意:continue应用于跳过后续本应该执行的代码。

因为continue可以跳过后续本应该执行的代码,而后续执行代码中可能包含循环跳出的设置如:i += 1。所以continue的使用会有死循环风险,需要单独处理循环跳出问题。

17、while...else...

据说使用while后面的else,如果while正常执行完毕,则执行else。如果while没有正常执行完毕如被break打断,则不会执行else。可以使用else是否执行来判断循环是否正常执行完毕,我觉得这并不合理,考虑下述代码:

 1 i = 11
 2 while i < 10:
 3     print(‘i is:‘, i)
 4     i += 1
 5     if i == 3:
 6         break
 7 else:
 8     print(‘循环正常执行完毕‘)
 9
10 # 循环没有正常执行完毕,实际上循环根本就没执行,else也被执行了。所以else被用于判断
11 # while是否正常执行我觉得并不合理。

18、while的使用

思考如下练习:

# 使用while,完成以下图形的输出

#
# *
# * *
# * * *
# * * * *
# * * * * *
# * * * *
# * * *
# * *
# *
 1 star = 1
 2 most_star = 5
 3 while star <= most_star:
 4     print(‘ *‘ * star)
 5     if star == most_star:
 6         while most_star > 0:
 7             most_star -= 1
 8             print(‘ *‘ * most_star)
 9         break
10     star += 1
11
12 row = 1
13 most_row = 5
14 while row <= most_row:
15     print(‘ *‘ * row)
16     row += 1
17 row = most_row - 1
18 while row > 0:
19     print(‘ *‘ * row)
20     row -= 1

while循环只能打印一个方向,如果是两个相反的方向,需要两个while。两个while可以写成第二个while放在第一个while的末尾。

原文地址:https://www.cnblogs.com/zzzlw/p/9127958.html

时间: 2024-10-07 04:29:53

python学习-基础知识-1的相关文章

Python学习基础知识概要

1.输入输出 输出实例 1 2 print 'hello','world' hello world 输入实例 1 2 3 4 5 name = raw_input(); print "hello,",name world hello,world 输入时提示实例 1 2 3 4 5 name = raw_input('please enter your name:'); print "hello,",name please enter your name:world

Python入门基础知识实例,值得收藏!

7月的编程语言指数榜已经发布,Python 在今年5月首次超越 Java 拿下榜首位置后,仍保持上涨趋势,正逐渐与 Java 拉开差距.(图为与去年 7 月数据对比) 上周为大家简单介绍了如何安装Python和配置环境?相信大家都将Python安装成功了吧~今天小白就为大家分享一些Python的基础知识,希望大家都能快速入门Python~ 1.在Python 语言中,对象是通过引用传递的. 在赋值时,不管这个对象是新创建的,还是一个已经存在的,都是将该对象的引用(并不是值)赋值给变量. 如:x=

Python学习基础篇第一篇——快速入门(适合初学者)

一.Python学习基础篇第一篇--(快速入门) 建议从Python2.7开始学习,Python2.7可以支持扩展大量的第三方类库,是目前比较成熟的版本 编写代码的软件推荐将python自带的IDLE和PyCharm集成IDE结合起来使用 1.1 Python命令行 Python命令行将以 >>> 开始,比如 >>>print 'Hello World!' 对于验证简单的命令可以在python自带的IDLE中完成  1.2 在Python自带的IDLE写一段小程序 在所

(八)从零开始学人工智能--统计学习:统计学习基础知识

目录 统计学习基础知识 1. 统计学习种类 1.1 监督学习 1.2 非监督学习 2. 统计学习中的基本概念 2.1 统计学习三要素:模型,策略,算法 2.2 欠拟合和过拟合 2.3 如何避免过拟合 2.4 过拟合产生的原因 2.5 最大似然估计和贝叶斯估计 3. 线性回归 3.1 经典线性回归 3.2 岭回归(ridge regression) 3.3 lasso回归和ElasticNet 4. 线性分类 4.1 感知机 4.2 逻辑回归(logistic regression) 4.3 So

Python爬虫基础知识及前期准备

学习爬虫有一小段时间了,于是决定把自己学爬虫时所学的,写过的代码以及看过的文档记录下来,权当小结.第一次写这些,如果有错误,请多指教. 首先我们需要了解一下什么是爬虫. 根据百度百科上给出的定义," 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本."简单来说,爬虫类似手动下载网页信息,比如小说.歌曲.说到这,或许会有疑问,既然这样,干嘛还去敲代码,直接人工处理不好吗?话是这么说,但如果下载的

VII python(1)基础知识

VII Python(1)基础知识 1989年诞生(同LinuxOS),google推崇,06年后才开始在中国流行,08年运维开始使用python www.python.org(主流OS默认配的python为2.6或2.7,最好在Ubuntu12.10上使用python,对于开发很方便,否则会浪费很多时间在装某一软件包) https://www.python.org/ftp/python/ Python(简单.容易上手.语法非常简明,任何功能都可实现:胶水语言,粘合剂,能与任何语言结合起来(如j

Python 面向对象基础知识

面向对象基础知识 1.什么是面向对象编程? - 以前使用函数 - 类 + 对象 2.什么是类什么是对象,又有什么关系? class 类: def 函数1(): pass def 函数2(): pass # obj是对象,实例化的过程 obj = 类() obj.函数1() ========== 面向对象不好 ============ ========== 函数编程好 ============== - 有时候,函数编程能实现?比较麻烦. - 面向对象非常的简单就能实现. 3.什么时候适用面向对象?

教你快速学会 Python 函数基础知识

一.函数基础 简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运行.Python中的函数在其他语言中也叫做过程或子例程,那么这些被包装起来的语句通过一个函数名称来调用. 有了函数,我们可以在很大程度上减少复制及粘贴代码的次数了(相信很多人在刚开始时都有这样的体验).我们可以把相同的代码可以提炼出来做成一个函数,在需要的地方只需要调用即可.那么,这样就提高了代码的复用率了,整体代码看起来比较简练,没有那么臃肿了. 函数在Python中是最基本的程序结构,用来最大化地

基于Linux的USB子系统学习 --- &lt;基础知识与USB协议概述&gt; ing

一.参考资料 1.<USB基础知识概论>  http://www.crifan.com/files/doc/docbook/usb_basic/release/html/usb_basic.html 2.<USB in a NutShell> http://www.beyondlogic.org/usbnutshell/usb1.shtml 3.<USB开发大全(第四版)> http://download.csdn.net/download/qqqq419276485/