01卷起来啊,未末家的张先生(初章)

卷起来啊,未末家的张先生(初章)

1、Python简介

(1)跨平台
(2)解释型语言(不需要编译),区别于Java,Java代码需要先编译,才能运行
(3)交互式语言
(4)面向对象语言

2、Python开发环境搭建

python是一门解释型语言,故需要安装python解释器
IDLE:python自带的开发工具
Python 3.8:命令行工具(交互式编程)
Python3.8 Manuals:技术文档
Python 3.8 Module:Python已安装的模块的文档
小知识:

  • 快捷打开目录:windows+e
  • python中的逻辑运算是使用英文的:and、or、not
  • python中"+"作为连接符使用时需要连接的数据类型相同
  • 查看python库版本:python --version 或python -V

2.1 python标准库和扩展库

python标准库:Lib目录下
python扩展库(第三方库):Lib/site-packages目录下

3、PyCharm的安装与使用

小技巧:python文件模板设置路径:Settings-Editor-File and Code Template

4、print函数的使用

print(1, '10')			#1 10,默认使用空格隔开
print(1 + 'Hello')		#错误,int类型和str类型不可以使用 + 操作符
print('Hello',end='')	#不换行打印输出:HelloWorld
print('World')

小知识:

  • 十进制数转换成各种进制,除以各种进制的数,直到商为0,倒着取数
  • SyntaxError:语法错误
0b开头:二进制
0o开头:八进制
0x开头:十六进制
bin(n):将十进制转换成二进制
oct(n):将十进制转换成八进制
hex(n):将十进制转换成十六进制

5、转义字符

即反斜杠+想要实现的转义功能首字母
转义字符的作用:当字符串中包含反斜杠、单引号和双引号等有特殊用途的字符时,必须使用反斜杠对这些字符进行转义。
例如:
换行:\n
回车:\r
tab水平制表符:\t,4个空格的位置,占据一个制表位

print('123\t456')	
print('1234\t567')

不希望转义字符起作用,在字符串前加上字母R,大小写均可。

print(r'123456\n789')	#123456\n789 

6、二进制与字符编码

1TB = 1024GB
1GB = 1024MB
1MB = 1024kB
1KB = 1024byte
1Byte = 8bit

计算机是由逻辑电路组成的,它只能区分0和1
为了让计算机认识并区分更多的东西,将一些符号和数字进行对应,然后做成一张ASCII表,告诉计算机某个符号需要使用哪个整数表示。例如大写字母’A’用十进制65表示
通俗易懂的解释:编码表就是规定了哪一个字符用哪一个数字去表示

例如:'乘'这个汉字再在计算机中的表示
print(chr(0b100111001011000))

print(ord('乘'))

7、Python中的标识符和保留字

import keyword

print(keyword.kwlist)

标识符:变量,函数,类,模块的名字就叫标识符
规则:

  • 字母、数字和下划线组成
  • 不能以数字开头
  • 不能是已存在的保留字
  • 区分大小写

8、变量的定义和使用

在这里插入图片描述
变量由三部分组成:
(1)内存地址:表示对象存储在计算机中的地址,使用内置函数id(obj)来获取
(2)类型:表示的是对象的数据类型,使用内置函数type(obj)来获取
(3)值:表示对象所存储的具体数据,使用print(obj)可以将值进行打印输出
内存图:name实际上存储的是对象的二进制的内存地址,指向自身存储的二进制内存地址所对应的对象

9、变量的多次赋值

例如:

#n赋初始值为3,实际上是将3这个对象的内存地址赋值给了n这个变量(引用)
n = 3
#n又被赋值为4,实际上是将4这个对象的内存地址赋值给了n这个变量(引用),n被重新赋值,故n指向的内存地址由3变成了4
n = 4

10、常用的数据类型

常用的数据类型:
(1)整数类型int:98
(2)浮点数类型float:3.14159
(3)布尔类型bool:True、False
(4)字符串类型str:‘Hello World’,“扶摇”

11、整数类型

英文为Integer,简写为int,可以表示正数、负数和零
整数的不同进制表示方式:
十进制:默认的进制
二进制:以0b开头
八进制:以0o开头
十六进制:以0x开头

12、浮点类型

浮点数由整数部分和小数部分组成
浮点数存储不精确性:使用浮点数进行计算时,可能会出现小数位数不确定的情况
在这里插入图片描述

13、布尔类型

用来表示真或假的值
True表示真,False表示假
布尔值可以转化为整数:True:1 False:0,故可以将整数类型和布尔类型直接相加,不需要转换

print(True + 1)		#2
print(False + 1)	#1

14、字符串类型

#s1,s2,s3的内存地址是相同的,即是同一个对象
s1 = 'hello'
s2 = s1
s3 = 'hello'

理解:s1和s2的内存地址相同,s1 = 'hello',将对象'hello'的内存地址赋值给引用s1,s2 = s1,将s1的内存地址赋值给s2

小知识:

  • s1,s2,s3内存地址相同的原因是因为字符串的驻留机制
    字符串类型又被称为不可变字符序列
    可以使用单引号、双引号、三引号来定义
    单引号和双引号定义的字符串必须在一行
    三引号定义的字符串可以分布在连续的多行

  • 不可变类型:当该数据类型的变量的值发生了改变,它所对应的内存地址也会发生改变,称为不可变类型

  • 可变类型:当该数据类型的变量的值发生了改变,它所对应的内存地址不会发生改变,称为可变类型

15、数据类型转换

为什么需要数据类型转换?
将不同数据类型的数据拼接在一起
在这里插入图片描述
str():将其它类型转成字符串str类型,例如:int类型、float类型、bool类型
int():将其它类型转换成整数int类型,例如:float类型、str类型、bool类型

注意:1、文字类和小数类字符串无法转化成整数 2、浮点数转换成整数,抹零取整
float():将其它类型转换成浮点数float类型,例如:int类型、str类型、bool类型 注意:整数转换成浮点数,末尾为.0

16、Python中的注释

注释:
注释的内容会被python解释器忽略

三种类型的注释:
单行注释:以井号’#‘开头
多行注释:’''三引号包围起来
中文编码声明注释:在文件开头加上中文声明注释,用以指定源码文件的编码格式(Python3不使用了)

17、input函数的使用

在这里插入图片描述
注意:input()函数返回值的类型也是str

name = input('请输入你的姓名:')	#未末家的张先生

print(name)						#未末家的张先生
print(type(name))				#<class,'str'>

18、Python中的运算符

加减乘除:+、—、*、/
整除://
模运算符(取余运算符):%
幂运算符号:**

print(1 / 2)	#0.5
print(11 // 5)	#2
print(11 // 2)	#5
print(2 ** 3)	#8

注意:
(1)整除时一正一负向下取整,例如:9 // -2 = -5 -9 // 2 = -5
(2)模运算一正一负要用公式计算:余数 = 被除数 - 除数 * (整除的商),计算商时需要带符号计算

例如:9 % -2 = 9 - (-2) * (9 // -2) = -1

19、赋值运算符

赋值运算符的执行顺序是从右往左,例如:a = 10,正确解读是将3的值赋值给a,常识说a = 3是不那么合理的。从编程角度准确的来讲应该是将对象10的内存地址赋值给a

#a,b,c的内存地址是一样的
a = 10
b = 10
c = 10

print(id(a))
print(id(b))
print(id(c))

理解:计算机在内存中给10这个对象开辟了一块内存空间,a,b,c三个引用分别指向10这个对象的内存空间(变量存储的实际是对象的内存地址,用于指向对象所在的内存空间),因此a,b,c这三个引用所存储的内存地址是一样的,都是10这个对象的内存地址

20、比较运算符

==比较的是对象的值
is比较的是对象的内存地址(即比较是不是同一个对象)
比较的结果是一个布尔值

a = 10

b = 10

print(a == b)	#true
print(a is b)	#true

21、布尔运算符

and:与运算符
or:或运算符
not:非运算符

in和not in:成员运算符:测试给定值是否为序列中的成员,例如字符串,列表或元组

str = 'hello'

print('h' in str)	#区分大小写

22、位运算符

&:按位与运算符
|:按位或运算符
^:按位异或运算符,相同为0,相反为1
~:按位取反运算符
<<:左移位运算符
右移位运算符:>>

后续需要把负数考虑在内:负数的按位与、按位或、左移、右移

小知识:
int类型的整数一般是占用4个字节,即32个比特位(1个比特位表示一位二进制数),即会用32位二进制数存储一个int类型的数据,(二进制的最高位)最前面一位数表示符号位,正数为0,负数为1

  • 计算机中用补码表示二进制数,正数的原码、反码、补码都相同,负数的补码 = 正数的原码取反后+1
    • 已知负数的补码,求二进制数:即补码 - 1,取反,取绝对值
    • +5在计算机中表示为:0000 …… 0000 0101
    • -5 在计算机中表示为:1111 …… 1111 1011
  • 负数的原码为该数对应的无符号数的二进制,将首位置1
  • 原码:0110
  • 反码:1001
  • 补码:反码+1,即1010

二进制,有符号数,首位为1的表示负数,首位为0的表示整数
无符号数没有正负数之分,所以也没有首位的限制

23、运算符的优先级

编码时可以用括号括起来清晰易懂

24、程序的组织结构-顺序结构

程序代码的执行是一行一行按顺序往下执行的
任何简单或者复杂的算法都是由:顺序结构、选择结构和循环结构这三种基本结构组合而成

25、对象的布尔值

Python中一切皆对象,所有的对象都有一个布尔值,获取对象的布尔值使用内置函数:bool()

以下对象的布尔值为False:False、数值0, 0.0、None、空字符串、空列表、空元组、空字典、空集合
除了上述的其它对象的bool值均为True

26、分支结构

#(1)单个if:

if 条件表达式:

	条件执行体

#(2)if...else:

if 条件表达式:

	条件执行体1

else:

	条件执行体2

#(3)if...elif...elif...else:

if 条件表达式1:

	条件执行体1

elif 条件表达式2:

	条件执行体2

elif 条件表达式3:

	条件执行体3

else:

	执行体4

#(4)嵌套if:

if 外层条件表达式:

	if 内层条件表达式:

		内层条件执行体1

	else:
		内层条件执行体2
else:
	外层条件执行体

小知识:
random模块:有许多产生随机数的方法,例如randint(start,end):产生一个[start,end]的随机数

27、条件表达式

条件表达式是if…else…的缩写
语法结构:x if 条件表达式 else y

运算规则:如果判断条件的布尔值为True,条件表达式的返回值为x,否则条件表达式的返回值为y

a = 1 if 1 < 2 else 0

28、pass语句

在这里插入图片描述

29、内置函数range()

range函数在不指定初始值的情况下,默认生成的序列是从0开始的。序列的每个元素都是int类型的整数

range函数产生<class,range>类型的数据,range数据存储了一个个int类型的数据(相当于只能存储int类型的数组)

30、循环结构-while

#打印1-9
a = 1
while a < 10:
    print(a)
    a += 1    
    
#计算1-100的和
a = 1
sum = 0
while a <= 100:		
    sum += a
    a += 1        

31、循环结构-for…in…

#遍历字符串
for item in 'Hello':
    print(item)

#遍历range序列    
for item in range(1,10):
    print(item)
    
#计算1-100的偶数
sum = 0
for item in range(1,101):
    if item % 2 == 0:
    	sum += item
print(sum)

练习题:求100-1000的水仙花数

for item in range(1,1001):
    a = item % 10			#个位数字
    b = item % 100 // 10	#十位数字,注意十位数字比较容易求错
    c = item // 100			#百位数字
    if a**3 + b**3 + c**3 == item
    	print(item)

小知识:

  • for…else语句:for循环结束执行时(全部执行完没有遇到break结束循环),执行else语句,可以在else语句中打印循环体结束后的item,如果有break语句提前结束循环,则不进入else分支。
  • while…else和for…else同理
  • 什么时候用while,什么时候用for:
    • 循环次数已知,用for
    • 循环次数不确定,用while

32、流程控制语句break

for item in range(1,4):
    pwd = input("请输入你的密码:")
    if pwd == '811169':
        print('密码正确')
        break
    else:
        print('密码错误,请重新输入')

33、流程控制语句continue

#输出1-50之间所有5的倍数
for item in range(1,51):
    if item % 5 != 0:
        continue
    else:
        print(item)

continue和break总结:continue用于跳过当前循环体这一次的循环执行,开始执行下一次。而break是退出当前循环体

34、else语句

while循环和for循环正常运行完,在没有遇到break语句时执行else

35、嵌套循环(二重循环)

循环结构中又嵌套了另外的完整的循环结构,其中内层循环作为外层循环的循环体执行

核心:外层循环控制行与换行,内层循环控制列

二重循环打印指定图形的时候,先找出行和列的个数关系,进而确定外层循环的次数和内层循环次数之间的关系

(1)九九乘法表

for item1 in range(1,10):
    for item2 in range(1,item1 + 1):
        print(item2,'*',item1,'=',str(item1*item2),end="\t")
    print()

36、二重循环中的break和continue

continue和break总结:continue用于跳过当前循环体这一次的循环执行,开始执行下一次。而break是退出当前循环体

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
对于这个问题,我们可以先从数据分析的角度出发,再选择合适的工具来绘制图形。 1. 散点图 通过绘制2000-2019年年末总人口的散点图,我们可以观察到人口的增长趋势和波动情况。如果发现人口增长率在某些年份有明显的变化,那么我们可以进一步探究背后的原因。 2. 折线图 通过绘制2000-2019年年末总人口的折线图,我们可以更加清晰地看到人口的变化趋势。如果需要进行预测,我们可以根据折线图来判断未来的人口发展趋势。 3. 散点图 通过绘制2000-2019年末各年龄段总人口的散点图,我们可以观察到各年龄段的人口数量分布情况。如果发现某些年龄段的人口数量有明显变化,那么我们可以进一步研究这些变化的原因。 4. 点线图 通过绘制2000-2019年未末各年龄段总人口的点线图,我们可以更加清晰地看到各年龄段人口数量的变化趋势。如果需要进行预测,我们可以根据点线图来判断未来各年龄段人口数量的变化趋势。 5. 饼图 通过绘制2019年各年龄段年末总人口的饼图,我们可以更加直观地看到各个年龄段人口数量的占比情况。如果需要比较各年龄段的人口数量占比,那么饼图是一个很好的选择。 6. 柱形图 通过绘制2019年各年龄段年末总人口的柱形图,我们可以更加清晰地看到各个年龄段人口数量的大小关系。如果需要比较各年龄段的人口数量大小,那么柱形图是一个很好的选择。 根据不同的需求,我们可以选择不同的图形来展示数据,帮助我们更好地理解数据背后的含义。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值