百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python入门知识点总结,Python三大数据类型、数据结构、控制流

off999 2024-09-29 16:15 25 浏览 0 评论

Python基础的重要性不言而喻,是每一个入门Python学习者所必备的知识点,作为Python入门,这部分知识点显得很庞杂,内容分支很多,大部分同学在刚刚学习时一头雾水。

本节将Python的知识点进行总结与归纳,节选部分在数据分析过程中用到比较多的一些知识,例如字符串、列表、元组、字典等的用法,以及控制流if、for、while的用法,下面一起来学习。

Python 是一种解释型、面向对象、动态数据类型的高级程序设计语言。Python基础知识包含Python数据类型,数据结构,控制流等,与其他高级语言类似,顺序语句、条件语句、循环语句等是其基本结构。

1.Python基本命令

1.1 列出已安装的包

pip list

1.2 查看可升级的包

pip list -o

1.3 安装包

pip install SomePackage # 最新版本
pip install SomePackage==1.5.0 # 指定版本

1.4 镜像站安装

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple some-package

1.5 升级包

pip install --upgrade SomePackage # 升级至最新版本
pip install --upgrade SomePackage==1.5.0 # 升级为指定版本

1.6 卸载包

pip uninstall SomePackage
#导入sys库只是为了确认一下Python的版本
import sys
#导入pandas
import pandas as pd
import numpy
import matplotlib
print('Python 版本为:' + sys.version)
print('Pandas 版本为:' + pd.__version__)
print('Numpy 版本为:' + pd.__version__)
print('Matplotlib 版本为:' + matplotlib.__version__)

2.变量与保留字

2.1 变量

变量相当于一个内存容器,可以指定存入不同的数据类型,可以是整数,小数或字符。

#Jupyter notebook打印多个变量结果
from IPython.core.interactiveshell import InteractiveShell
InteractiveShell.ast_node_interactivity='all'

使用如上的代码可以使得变量结果多行显示。

name = "大话数据分析" # 字符串
age = 18 # 赋值整型变量
height = 178.4 # 浮点型
name
age
height

2.2 保留字

Python中的保留字不能用作变量名称,常见的Python保留字如下所示。

import keyword
print(keyword.kwlist)

['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']

3. 三大数据类型

3.1 str

3.1.1 初识字符串

# 字符串定义
a = 'hello world'
a

'hello world'

type(a)#类型
len(a)#长度

str

Out[82]:11

3.1.2 索引和切片

使用[头下标:尾下标]来切片,其中下标是从 0 开始算起,切片的范围前闭后开,表示方括号的左边可以切切到,而右边切不到。

# 切片索引
a[0:5],a[:5]

('hello', 'hello')

a[:],a[::1]

('hello world', 'hello world')

#负号代表从右边开始截取,这里表示取反
a[::-1]

'dlrow olleh'

3.1.3 方法

'-'.join(a)
a.replace('world','boy')
a.zfill(15)#返回指定长度的字符串,原字符串右对齐,前面填充0


today=['2015','10','15']
print("-".join(today))

'h-e-l-l-o- -w-o-r-l-d'

Out[6]:'hello boy'

Out[6]:'0000hello world'

2015-10-15

a.count('o') #字符串计数
a.index('o') #字符串索引
a.find('o') #字符串查找
a.capitalize()#首字母大写
a.title() #设置为标题
a.upper() #字母大写
a.lower() #字母小写
a.startswith('h') #开头包含的字符

2

Out[70]:4

Out[70]:4

Out[70]:'Hello world'

Out[70]:'Hello World'

Out[70]:'HELLO WORLD'

Out[70]:'hello world'

Out[70]:True

s = '**2021/12/16**'
s.strip('*')#去除头和尾部字符
s.lstrip('*')#去除左边字符
s.rstrip('*')#去除右边字符
s.strip('*').split('/') #去除头和尾部字符,并按照/分隔开

'2021/12/16'

'2021/12/16**'

'**2021/12/16'

['2021', '12', '16']

3.1.4 字符运算

# 运算符运算:+ 和 *
s = '大话数据分析'
'Hello' + ' ' + s
s * 3

'Hello 大话数据分析'

'大话数据分析大话数据分析大话数据分析'

3.2 int

num = 10
print(type(num))
#基本的算术运算
print('加法:',num + 2)
print('减法:',num - 2)
print('乘法:',num * 2)
print('除法',num / 2)
print('地板除法',num // 2)
print('幂运算',num ** 2)
print('余数',num % 2)

加法: 12

减法: 8

乘法: 20

除法 5.0

地板除法 5

幂运算 100

余数 0

#算术运算的顺序,先计算括号里边的内容,再乘除后加减
print(num * (2 + 1))

30

#数字自增长
num = 10
num = num  + 1
print(num)
#或者+=方式
num = 10
num += 1
print(num)
#数字自乘积
num = 10
num = num  * 5
print(num)


#使用*=
num = 10
num *= 5
print(num)

11

11

50

50

3.3 float

num = 10.01
print(type(num))

<class 'float'>

#基本的算术运算
print('加法:',num + 2)
print('减法:',num - 2)
print('乘法:',num * 2)
print('除法',num / 2)
print('地板除法',num // 2)
print('幂运算',num ** 2)
print('余数',num % 2)

加法: 12.01

减法: 8.01

乘法: 20.02

除法 5.005

地板除法 5.0

幂运算 100.20009999999999

余数 0.009999999999999787

#算术运算的顺序,先计算括号里边的内容,再乘除后加减
print(num * (2 + 1))

30.03

#数字自增长
num = 10.0
num = num  + 1
print(num)
#或者+=方式
num = 10.0
num += 1
print(num)
#数字自乘积
num = 10.0
num = num  * 5
print(num)
#或者*=
num = 10.0
num *= 5
print(num)

11.0

11.0

50.0

50.0

3.4 类型转化

str,int,float数据类型相互转化。

#将string内容为数字,字符串相连
num1 = '10'
num2 = '20'
num3 = '30.0'
print('字符串相连:',num1+num2+num3)

#使用int()函数将字符型转换为int,float函数将字符型转换为float
num1_int = int(num1)
num2_int = int(num2)
num3_int = int(float(num3))
print('数值相加:',num1_int + num2_int + num3_int)

字符串相连:102030.0

数值相加:60

4. 三大数据结构

4.1 列表

4.1.1 初识列表

列表是 Python 中使用最频繁的数据类型,列表中的每个元素都可变的,可以对每个元素进行修改和删除,且列表是有序的,每个元素的位置是确定的,可以用索引去访问每个元素,并且,列表中的元素可以是Python中的任何对象,比如字符串、整数、元组、也可以是list等Python中的对象。

# 列表定义
lst = [1,2,3,4,5,6,7,8,9]
lst

[1, 2, 3, 4, 5, 6, 7, 8, 9]

lst = list(range(5))
lst

[0, 1, 2, 3, 4]

# 类型和长度
type(lst)
len(lst)

4.1.2 索引和切片

使用[头下标:尾下标]来截取部分字符串,其中下标是从 0 开始算起,可以是正数或负数,下标可以为空表示取到头或尾。

# 索引
lst = [1,2,3,4,5,6,7,8,9]
lst[0]
lst[-1]

9

# 切片
lst[0:4]
lst[:4]
lst[0:4:1]
lst[:]
lst[::-1]

[0, 1, 2, 3]

[0, 1, 2, 3]

[0, 1, 2, 3]

[0, 1, 2, 3, 4]

[4, 3, 2, 1, 0]

lst[::1] #缺省为1,默认间隔一个位置提取
lst[::2] #步长为 2(间隔一个位置)来截取

[0, 1, 2, 3, 4]

[0, 2, 4]

4.1.3 方法

# append,列表末尾添加新的对象
lst = [0,1,2,3,4]
lst.append(5)
lst

[0, 1, 2, 3, 4, 5]

#extend合并列表内容
lst = [0,1,2,3,4]
lst.extend([5])
lst

[0, 1, 2, 3, 4, 5]

#insert指定位置插入数据
lst = [0,1,2,3,4]
lst.insert(1,5)
lst

[0, 5, 1, 2, 3, 4]

lst = [0,1,2,3,4]
lst.copy()

[0, 1, 2, 3, 4]

# remove
lst = [0,1,2,3,4]
lst.remove(4)
lst

[0, 1, 2, 3]

# count,index
lst = [7,8,5,4,3,3,5,6,7,5]
lst.count(5)
lst.index(3)

3

4

# 默认升序排列
lst = [7,8,5,4,3,3,5,6,7,5]
lst.sort()
lst

[3, 3, 4, 5, 5, 5, 6, 7, 7, 8]

4.1.4 列表运算

# 运算符运算:+ 和 *
lst = [1,2,3,4]
lst + [3,4,5]
lst * 2

[1, 2, 3, 4, 3, 4, 5]

[1, 2, 3, 4, 1, 2, 3, 4]

4.2 元组

元组可理解为一个固定列表,一旦初始化其中的元素便不可修改,只能对元素进行查询。

4.2.1 初识元组

# 元组的定义
t = (0, 1, 2, 3, 4)
t

(0, 1, 2, 3, 4)

t = tuple(range(5))
t

(0, 1, 2, 3, 4)

# 属性和长度
type(t)
len(t)

tuple

Out[8]:5

4.2.2 索引和切片

# 索引
t = (0, 1, 2, 3, 4)
t[0]
t[1]
t[-1]

0

1

4

# 切片
t = (0, 1, 2, 3, 4)
t[0:4]
t[:4]
t[0:4:1]

(0, 1, 2, 3)

Out[10]:(0, 1, 2, 3)

Out[10]:(0, 1, 2, 3)

t = (0, 1, 2, 3, 4)
t[:]
t[::-1]

(0, 1, 2, 3, 4)

Out[14]:(4, 3, 2, 1, 0)

t = (0, 1, 2, 3, 4)
t[::1]
t[::2]

(0, 1, 2, 3, 4)

Out[13]:(0, 2, 4)

# count---index
t = (2, 1, 2, 4, 2)
t.count(2)
t.index(2)
t.index(4)

3

Out[16]:0

Out[16]:3

4.2.3 元组运算

# 运算符运算:+ 和 *
t = (1, 2, 3, 4)
t + (4,5,6)
t * 2

(1, 2, 3, 4, 4, 5, 6)

Out[17]:(1, 2, 3, 4, 1, 2, 3, 4)

4.3 字典

字典中的数据必须以键值对的形式出现,其中,键是唯一的,不可重复,值可重复,字典中键(key)是不可变的,为不可变对象,不能进行修改;而值(value)是可以修改的,可以是任何对象。

4.3.1 初识字典

# 字典的定义: 键值对
d = {'a':10,'b':20,'c':30}
d

{'a': 10, 'b': 20, 'c': 30}

# 属性和长度
d = {'a':10,'b':20,'c':30}
type(d)
len(d)

4.3.2 索引和切片

# 索引
d = {'a':10,'b':20,'c':30}
d['b']

20

4.3.3 方法

# keys---values---items
d = {'a':10,'b':20,'c':30}
d.keys()
d.values()
d.items()

dict_keys(['a', 'b', 'c'])

Out[24]:dict_values([10, 20, 30])

Out[24]:dict_items([('a', 10), ('b', 20), ('c', 30)])

# update
d = {'a':10,'b':20,'c':30}
d.update({'d':40})
d
# pop
d = {'a':10,'b':20,'c':30}
d.pop('a')
# get
d = {'a':10,'b':20,'c':30}
d.get('b')

5. 三大控制流

5.1 if语句

当 if "判断条件" 成立时,则执行后面的语句,else 为可选语句,当条件不成立时可以执行该语句。


#if...else语句
score = 60
if score <60:
    print('不及格')
    print('还需要在努力!')
else:
    print('很棒!及格了')

很棒!及格了

#if...elif语句
score = 75
if score <60:
    print('不及格')
    print('还需要在努力!')
elif score <70:
    print('成绩:{}'.format('及格'))
elif score <80:
    print('成绩:{}'.format('中等'))
elif score <90:
    print('成绩:{}'.format('良好'))
elif score <100:
    print('成绩:{}'.format('优秀'))

成绩:中等

5.2 while语句

在某特定条件下,循环执行某命令。


#while
a = 0
i = 100


while i < 100:
        a=a+i
        i=i+1
print(a)

5050

5.3 while……else……语句

else中的语句会在循环正常执行完(即不是通过break跳出而中断的)的情况下执行。

#while…else…
a = 1
b = 1


while a > b:
    print(a)
else:
    print('数值大小相等')

数值大小相等

#while…if…else…
a = 1
b = 1




while a > b:
    print(a)
    if a < b:
        print(b)
else:
    print('数值大小相等')

数值大小相等

#break 语句,跳出当前循环,结束语句
a = 10
b = 50


while a < b:
    print(b)
    a += 10
a = 10
b = 50


while a < b:
    print(b)
    a += 10
    break

5.4 for 循环语句

对集合(如列表或元组)或迭代器进行迭代。

range函数用于产生一组间隔相等的整数序列的可迭代对象,可以指定起始值、终止值以及步长,常用于按索引对序列进行迭代。

a=0
for i in range(1,101):
        a = a+i
print(a)

5050

#for
for i in range(1,5):
    print(i * 10)

10

20

30

40

#for…if…else…
for i in range(1,5):
    if i < 3:
        print(str(i) + 'Python')
    else:
        print(str(i) + 'Java')

1Python

2Python

3Java

4Java

for i in range(1,5):
    print(i)
    if i > 2:
        break

1

2

3

5.5循环控制语句

  • break:结束(终止)循环
  • continue:中止当前循环,跳到下一次循环的开始
  • while true/break:实现一个永远不会自己停止的循环
  • else:在使用break时,可以使用else语句在没有调用break时执行对应的语句
  • pass:不做任何事情,一般用做占位语句
for a in 'This is Python!':
    if a == ' ':
        pass
        print('passed!')
        break
    print(a)

相关推荐

apisix动态修改路由的原理_动态路由协议rip的配置

ApacheAPISIX能够实现动态修改路由(DynamicRouting)的核心原理,是它将传统的静态Nginx配置彻底解耦,通过中心化配置存储(如etcd)+OpenRest...

使用 Docker 部署 OpenResty Manager 搭建可视化反向代理系统

在之前的文章中,xiaoz推荐过可视化Nginx反向代理工具NginxProxyManager,最近xiaoz还发现一款功能更加强大,界面更加漂亮的OpenRestyManager,完全可以替代...

OpenResty 入门指南:从基础到动态路由实战

一、引言1.1OpenResty简介OpenResty是一款基于Nginx的高性能Web平台,通过集成Lua脚本和丰富的模块,将Nginx从静态反向代理转变为可动态编程的应用平台...

OpenResty 的 Lua 动态能力_openresty 动态upstream

OpenResty的Lua动态能力是其最核心的优势,它将LuaJIT嵌入到Nginx的每一个请求处理阶段,使得开发者可以用Lua脚本动态控制请求的生命周期,而无需重新编译或rel...

LVS和Nginx_lvs和nginx的区别

LVS(LinuxVirtualServer)和Nginx都是常用的负载均衡解决方案,广泛应用于大型网站和分布式系统中,以提高系统的性能、可用性和可扩展性。一、基本概念1.LVS(Linux...

外网连接到内网服务器需要端口映射吗,如何操作?

外网访问内网服务器通常需要端口映射(或内网穿透),这是跨越公网与私网边界的关键技术。操作方式取决于网络环境,以下分场景详解。一、端口映射的核心原理内网服务器位于私有IP地址段(如192.168.x.x...

Nginx如何解决C10K问题(1万个并发连接)?

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。Nginx是大型架构的必备中间件,下面我就全面来详解NginxC10k问题@mikechen文章来源:mikec...

炸场!Spring Boot 9 大内置过滤器实战手册:从坑到神

炸场!SpringBoot9大内置过滤器实战手册:从坑到神在Java开发圈摸爬滚打十年,见过太多团队重复造轮子——明明SpringBoot自带的过滤器就能解决的问题,偏偏要手写几十...

WordPress和Typecho xmlrpc漏洞_wordpress主题漏洞

一般大家都关注WordPress,毕竟用户量巨大,而国内的Typecho作为轻量级的博客系统就关注的人并不多。Typecho有很多借鉴WordPress的,包括兼容的xmlrpc接口,而WordPre...

Linux Shell 入门教程(六):重定向、管道与命令替换

在前几篇中,我们学习了函数、流程控制等Shell编程的基础内容。现在我们来探索更高级的功能:如何控制数据流向、将命令链接在一起、让命令间通信变得可能。一、输入输出重定向(>、>>...

Nginx的location匹配规则,90%的人都没完全搞懂,一张图让你秒懂

刚配完nginx网站就崩了?运维和开发都头疼的location匹配规则优先级,弄错顺序直接导致500错误。核心在于nginx处理location时顺序严格:先精确匹配=,然后前缀匹配^~,接着按顺序正...

liunx服务器查看故障命令有那些?_linux查看服务器性能命令

在Linux服务器上排查故障时,需要使用一系列命令来检查系统状态、日志文件、资源利用情况以及网络状况。以下是常用的故障排查命令,按照不同场景分类说明。1.系统资源相关命令1.1查看CPU使...

服务器被入侵的常见迹象有哪些?_服务器入侵可以被完全操纵吗

服务器被入侵可能会导致数据泄露、服务异常或完全失控。及时发现入侵迹象能够帮助你尽早采取措施,减少损失。以下是服务器被入侵的常见迹象以及相关的分析与处理建议。1.服务器被入侵的常见迹象1.1系统性能...

前端错误可观测最佳实践_前端错误提示

场景解析对于前端项目,生产环境的代码通常经过压缩、混淆和打包处理,当代码在运行过程中产生错误时,通常难以还原原始代码从而定位问题,对于深度混淆尤其如此,因此Mozilla自2011年开始发起并...

8个能让你的Kubernetes集群“瞬间崩溃”的配置错误

错误一:livenessProbe探针“自杀式”配置——30秒内让Pod重启20次现象:Pod状态在Running→Terminating→CrashLoopBackOff之间循环,重启间隔仅...

取消回复欢迎 发表评论: