学习记录(week1)

学习内容来源于互联网

Day1

1.理论性内容 

 2.安装教学

Day 2:基础语法和number 类型

 一、Python 基础语法:

1.使用缩进来代替其他语块声明,一般建议每个层级用4个空格来缩进

2.声明单行字串,引用单/双引号都成,注意对字串中的引号进行逃逸处理(就是在字串中的引号之前加入\)

3.注释:单行注释采用 #开头,多行注释使用三个单引号(''')或三个双引号(""")

4.数据类型:python中数有四种类型:整数、长整数、浮点数和复数。

-整数, 如 1

-长整数 是比较大的整数

-浮点数 如 1.23、3E-2

-复数 如 1 + 2j、 1.1 + 2.2j

5.字符串:

python中单引号和双引号使用完全相同。

使用三引号('''或""")可以指定一个多行字符串。

转义符 '\'

自然字符串, 通过在字符串前加r或R。 如 r"this is a line with \n" 则\n会显示,并不是换行。

python允许处理unicode字符串,加前缀u或U, 如 u"this

is an unicode string"。

字符串是不可变的。

按字面意义级联字符串,如"this " "is "

"string"会被自动转换为this is string。


二、Python 变量类型 number:

(一)W3C部分学习内容

Python中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。

在Python中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型。

Python 3中有六个标准的数据类型:

Numbers(数字)、String(字符串)、List(列表)、Tuple(元组)、Sets(集合)、Dictionaries(字典)

只看Numbers(数字)

Python 3支持int、float、bool、complex(复数)。

数值类型的赋值和计算都是很直观的,就像大多数语言一样。内置的type()函数可以用来查询变量所指的对象类型。


在Python中,能够直接处理的数据类型有以下几种:

整数

Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样,例如:1,100,-8080,0,等等。

计算机由于使用二进制,所以,有时候用十六进制表示整数比较方便,十六进制用0x前缀和0-9,a-f表示,例如:0xff00,0xa5b4c3d2,等等。

浮点数

浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,比如,1.23x109和12.3x108是完全相等的。浮点数可以用数学写法,如1.23,3.14,-9.01,等等。但是对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.23x109就是1.23e9,或者12.3e8,0.000012可以写成1.2e-5,等等。

整数和浮点数在计算机内部存储的方式是不同的,整数运算永远是精确的(除法难道也是精确的?是的!),而浮点数运算则可能会有四舍五入的误差。

字符串

字符串是以单引号'或双引号"括起来的任意文本,比如'abc',"xyz"等等。请注意,''或""本身只是一种表示方式,不是字符串的一部分,因此,字符串'abc'只有a,b,c这3个字符。如果'本身也是一个字符,那就可以用""括起来,比如"I'm

OK"包含的字符是I,',m,空格,O,K这6个字符。

如果字符串内部既包含'又包含"怎么办?可以用转义字符\来标识。

转义字符\可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\\表示的字符就是\。


布尔值

布尔值和布尔代数的表示完全一致,一个布尔值只有True、False两种值,要么是True,要么是False,在Python中,可以直接用True、False表示布尔值(请注意大小写),也可以通过布尔运算计算出来:


布尔值可以用and、or和not运算。

and运算是与运算,只有所有都为True,and运算结果才是True:

or运算是或运算,只要其中有一个为True,or运算结果就是True:

not运算是非运算,它是一个单目运算符,把True变成False,False变成True:

布尔值经常用在条件判断中,比如:

ifage >=18:

    print('adult')

else:

    print('teenager')


空值

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

此外,Python还提供了列表、字典等多种数据类型,还允许创建自定义数据类型,我们后面会继续讲到。


变量

变量的概念基本上和初中代数的方程变量是一致的,只是在计算机程序中,变量不仅可以是数字,还可以是任意数据类型。

变量在程序中就是用一个变量名表示了,变量名必须是大小写英文、数字和_的组合,且不能用数字开头,比如:

在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量

变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错。和静态语言相比,动态语言更灵活,就是这个原因。

请不要把赋值语句的等号等同于数学的等号。比如下面的代码:

x = 10

x = x + 2

如果从数学上理解x = x + 2那无论如何是不成立的,在程序中,赋值语句先计算右侧的表达式x + 2,得到结果12,再赋给变量x。由于x之前的值是10,重新赋值后,x的值变成12。

最后,理解变量在计算机内存中的表示也非常重要。当我们写:

a = 'ABC'

时,Python解释器干了两件事情:

[if !supportLists]1.  [endif]在内存中创建了一个'ABC'的字符串;

[if !supportLists]2.  [endif]在内存中创建了一个名为a的变量,并把它指向'ABC'。

也可以把一个变量a赋值给另一个变量b,这个操作实际上是把变量b指向变量a所指向的数据。


常量

所谓常量就是不能变的变量,比如常用的数学常数π就是一个常量。在Python中,通常用全部大写的变量名表示常量:

PI = 3.14159265359

但事实上PI仍然是一个变量,Python根本没有任何机制保证PI不会被改变,所以,用全部大写的变量名表示常量只是一个习惯上的用法,如果你一定要改变变量PI的值,也没人能拦住你。

最后解释一下整数的除法为什么也是精确的。在Python中,有两种除法,一种除法是/:

>>> 10 / 3

3.3333333333333335

/除法计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数:

>>> 9 / 3

3.0

还有一种除法是//,称为地板除,两个整数的除法仍然是整数:

>>> 10// 3

3

你没有看错,整数的地板除//永远是整数,即使除不尽。要做精确的除法,使用/就可以。

因为//除法只取结果的整数部分,所以Python还提供一个余数运算,可以得到两个整数相除的余数:

>>> 10 % 3

1

无论整数做//除法还是取余数,结果永远是整数,所以,整数运算结果永远是精确的。


小结

Python支持多种数据类型,在计算机内部,可以把任何数据都看成一个“对象”,而变量就是在程序中用来指向这些数据对象的,对变量赋值就是把数据和变量给关联起来。

对变量赋值x = y是把变量x指向真正的对象,该对象是变量y所指向的。随后对变量y的赋值不影响变量x的指向。

注意:Python的整数没有大小限制,而某些语言的整数根据其存储长度是有大小限制的,例如Java对32位整数的范围限制在-2147483648-2147483647。

Python的浮点数也没有大小限制,但是超出一定范围就直接表示为inf(无限大)。


Day3:认识string 类型

Python中的字符串str用单引号(' ')或双引号(" ")括起来,同时使用反斜杠(\)转义特殊字符。

如果你不想让反斜杠发生转义,可以在字符串前面添加一个r,表示原始字符串

另外,反斜杠可以作为续行符,表示下一行是上一行的延续。还可以使用"""..."""或者'''...'''跨越多行。

字符串可以使用 + 运算符串连接在一起,或者用 * 运算符重复:

Python中的字符串有两种索引方式,第一种是从左往右,从0开始依次增加;第二种是从右往左,从-1开始依次减少。

注意,没有单独的字符类型,一个字符就是长度为1的字符串。

还可以对字符串进行切片,获取一段子串。用冒号分隔两个索引,形式为变量[头下标:尾下标]。

截取的范围是前闭后开的,并且两个索引都可以省略:


注:字符串中,最外层的单引号和双引号里的东西都可以打出来,但是单引号和双引号本身不会。单引号之内有单个双引号可以打出来,双引号之内有单个单引号可以打出来,但是同类型引号就会发生误解。

如果想在单引号内打单引号,就要用到反斜杠或把外层改成双引号。

反斜杠会保护其后的单个引号。

如果字符串包含有单引号但不含双引号,则字符串会用双引号括起来,否则用单引号括起来。


跨行的字面字符串可用以下几种方法表示。\n续行符,\n\续行在下一行

1.使用 \n 来添加新行

使用续行符,即在每行最后一个字符后使用反斜线来说明下一行是上一行逻辑上的延续:

2.使用反斜线(\)来续行

其中的换行符仍然要使用 \n 表示——反斜杠后的换行符被丢弃了

3.前方加r

使用"原始"字符串,那么 \n 不会被转换成换行,行末的的反斜杠、源码中的换行符,都将作为数据包含在字符串内


切分,有两种方法

1.从左向右依次是0.1.2.3…

2.从右向左依次是-1.-2.-3….

有一个方法可以让您记住分切索引的工作方式,想像索引是指向字符之间,第一个字符左边的数字是 0。接着,有n个字符的字符串最后一个字符的右边是索引n,例如


纯英文的str可以用ASCII编码为bytes,内容是一样的,含有中文的str可以用UTF-8编码为bytes。含有中文的str无法用ASCII编码,因为中文编码的范围超过了ASCII编码的范围,Python会报错。

在bytes中,无法显示为ASCII字符的字节,用\x##显示。

反过来,如果我们从网络或磁盘上读取了字节流,那么读到的数据就是bytes。要把bytes变为str,就需要用decode()方法。

 

%运算符就是用来格式化字符串的。在字符串内部,%s表示用字符串替换,%d表示用整数替换,有几个%?占位符,后面就跟几个变量或者值,顺序要对应好。如果只有一个%?,括号可以省略。

常见的占位符有:

占位符替换内容

%d整数

%f浮点数

%s字符串

%x十六进制整数


Day 4 认识判断和循环语句

一、条件语句

Python程序语言指定任何非0和非空(null)值为true,0 或者 null为false。

Python 编程中 if 语句用于控制程序的执行。

其中"判断条件"成立时(非零),则执行后面的语句,而执行内容可以多行,以缩进来区分表示同一范围。

else 为可选语句,当需要在条件不成立时执行内容则可以执行相关语句。

当if有多个条件时可使用括号来区分判断的先后顺序,括号中的判断优先执行,此外 and 和 or 的优先级低于>(大于)、<(小于)等判断符号,即大于和小于在没有括号的情况下会比与或要优先判断。

Python中用elif代替了else if,所以if语句的关键字为:if– elif – else

注意:

1、每个条件后面要使用冒号(:),表示接下来是满足条件后要执行的语句块。

2、使用缩进来划分语句块,相同缩进数的语句在一起组成一个语句块。

3、在Python中没有switch – case语句。

4.判断时要用双等号


以下为if中常用的操作运算符:

操作符描述

<小于

<=小于或等于

>大于

>=大于或等于

==等于,比较对象是否相等

!=不等于

输入1982,结果报错:

Traceback(most recent call last):

  File "", line 1,in

TypeError: unorderable types: str() > int()

这是因为input()返回的数据类型是str,str不能直接和整数比较,必须先把str转换成整数。Python提供了int()函数来完成这件事情。

循环

Python提供了for循环和while循环(在Python中没有do..while循环):

循环类型描述

while 循环在给定的判断条件为  true 时执行循环体,否则退出循环体。

for 循环重复执行语句

嵌套循环你可以在while循环体中嵌套for循环。


Python中的循环语句有 for 和 while。

Python循环语句的控制结构。

同样需要注意冒号和缩进。另外,在Python中没有do..while循环。


for

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



Day5 作业&答疑 

1.int()和print(),均是函数。函数可以理解为一个“黑盒”,将一个东西放进去,发生一些“魔法”,然后给出一个结果。括号是放需要放进去的东西,print()的魔法是在控制端把结果输出,int()的魔法是把一个东西转化成一个“整型”(“整型”是一个数据类型,Python是一个不那么严格的编程语言,其他的如Java,C等对number的要求比较严格,会有int整型、double-C语言中的、float浮点即小数,例如在Python中给一个1234的字符串,可以用int变成整型,输入小数文字什么的不可以转换,会报错。函数只能尽力将可转换的转换为整数)

所以对“int()是限制只能输入整数的意思吗”回答为“不是!它是一个函数,作用是将可转换为整数的东西转换为整数,输入的小数、文字不能转换成整数所以会报错”。


PS.补充回顾Python中的数据类型

Python有五个标准的数据类型:Numbers(数字)String(字符串)List(列表)Tuple(元组)Dictionary(字典),其中属于集合类型的数据类型有列表、元组及字典。

数字(Numbers)

数字数据类型用于存储数值。四种不同的数字类型:int(有符号整型)、long(长整型[也可以代表八进制和十六进制])、float(浮点型)、complex(复数)。

float(浮点型)

浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。


2.关于两次判断:不能省略或者合并,因为根据辗转相除法的公理,需要a>b(辗转相除的公理:两个正整数a和b(a>b),它们的最大公约数等于a除以b的余数c和b之间的最大公约数。),所以需要先进行判断这样才能满足公理。

你可能感兴趣的:(学习记录(week1))