T03.python

2024-06-14 15:12
文章标签 python t03

本文主要是介绍T03.python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:range函数:

1:range(stop)创建[0,stop)整数序列

2:range(start,stop)创建[start,stop)整数序列

3:range(start,stop,step)创建步长为step[start,stop)整数序列

二:列表:

容器(0---n-1)/(-n--- -1)

1:创建

(1):使用[]

(2):使用list()

2:获取单个元素

lst = ['hello','world',98,'hello']
print(lst.index('hello'))# 0
#如果不存在 ValueError
#print(lst.index('hello',1,4)) #ValueError
print(lst.index('hello',1,4)) #3
print(lst[2])#98
print(lst[10])#IndexError

3:获取多个元素

列表名[start:stop:step] 范围:[start:stop)

在末尾添加一个元素lst.append()

在末尾添加至少一个元素lst.extend()

在列表的任意位置添加一个元素 lst.insert(位置,元素)

在列表的任意位置添加至少一个元素:切片:

4:列表的判断和遍历:

lst = [10,20,'python','hello']
print(10 in lst)#true
print(100 in lst)#false
print(10 not in lst)#false
for item in lst:
print(item)#遍历

s.count(x):返回序列s中出现x的总次数

5:元素的添加:

lst = [10,20,30]
lst.append(100)
lst2 = ['hello','world']
lst.extend(lst2)#[10, 20, 30, 100, 'hello', 'world']
lst.insert(1,90)#在1的位置上添加一个元素
#在任意位置添加N多个元素
lst3 = [True,False,'hello']
lst[1:]=lst3 #在1的位置开始切 [10,True,False,'hello]

ls += lt #更新列表ls,将列表lt元素增加到列表ls中
ls *= n #更新列表ls,其元素重复n次

6:元素的删除:

lst = [10,20,30,40,50,60,30]
lst.remove(30)#从列表中移除一个元素,重复元素移除第一个[10,20,40,50,60,30]
lst.pop(1 )#根据索引移除 第一个数被移除 [10,40,50,60,30]
lst.pop()#不指定参数则会删除最后一个元素 [10,40,50,60]
#切片操作删除至少一个元素,产生一个新的列表对象
new_list = lst[1:3]#[40,50]
#不产生
lst[1:3]=[] #lst:[10,60]
#清除所有元素
lst.clear() #[]
#删除列表
del lst

# 删除列表ls中第i元素

del ls[i]

7:列表修改:

lst = [10,20,30,40]
lst[2] = 100#[10,20,100,40]
lst[1:3] = [300,400,500,600]#[10,300,400,500,600,40]

8:列表的排序:

lst = [20,40,10,98,54]
lst.sort() #升序排序[10,20,40,54,98]
lst.sort(reverse=True)#降序排序[98,54,40,21,10]
lst.sort(reverse=False)#升序排序[10,20,40,54,98]
new_list = sorted(lst) #[10,20,40,54,98]
desc_list = sorted(lst,reverse=True)#降序排序

9:列表生成式:

lst = [i for i range(1,10)]#[1,2,3,4,5,6,7,8,9]
lst1 = [i for i range(1,10)]#[1,4,9,16,25,36,49,64,81]

三:字典(键值对):(键不能重复,值可以)(不可变对象)(无序)(可以动态伸缩)(内存大)

10:copy 列表:

# 生成一个新列表,赋值ls中所有元素

ls.copy()

1:创建:

scores = {'张三':100, '李四':98, '王五':45}#用{}
dict(name='jack', age=20)#dict 用()
#空字典:
(1):n = {} 花括号
(2):n = dict() 内置函数

2:字典元素的获取(值):

scores = {'张三':100, '李四':98, '王五':45}

scores = {'张三':100, '李四':98, '王五':45}
print(scores['张三'])
print(scores.get('张三'))

(1)用[] 若查找的键不存在,则会报错

(2):使用get() 若查找的键不存在,则会输出None

3:key 的判断是否存在

scores = {'张三':100, '李四':98, '王五':45}
print('张三' in scores) #True
print('张三' not in scores) #False

4:删除操作:del scores['张三']

5:清空操作:scores.clear()

6:添加操作:scores['陈六'] = 98

7:修改操作:scores['陈六'] = 100#直接重新赋值

8:获取字典的键值对:

scores = {'张三':100, '李四':98, '王五':45}
m = scores.keys()
print(m)
n = scores.values()
print(m)
k = scores.items()
print(m)
9:字典的遍历:

scores = {'张三':100, '李四':98, '王五':45}
for i in scores:
print(i,scores[i],scores.get(i)) 键 值 值

10:字典生成:

四:元组
不可变序列 ,无删减改操作
创建方式:
1:t=(‘hello’,‘world’)
特殊:若只有一个元素:
t=(‘hello’,) 逗号不能省!
2:内置函数: t=tuple((‘hello’,‘world’) )
3:空元组创建:{
t=()
t=tuple()
}

元组的遍历:
1:for i in t:
print(i)
2:print(t[0])

五:集合:(没有值的字典):

1:转化(特点:没有重复元素)

s1 = {'py',1,3,3,5,5}# 集合中元素不重复 只存储一个
s2 = set(range(5))# 0-5的整数集合
s3 = set([1,2,2,3,3])#将列表转化成了集合 去除了重复元素
s4 = set((3,4,5,5))#将元组转化成了集合 去除了重复元素
s5 = set({1,2,2,3})#集合类型不变 去除了重复元素

2:创建:

s = set()

若直接使用{},类型是字典。

3:元素判断:

in / not in

4:增加操作:

(1):add()

(2):update()

4:删除操作:

remove() 删除指定元素

discard() 删除指定元素

pop() 一次值删除一个任意元素

clear() 清空集合

5:集合的关系(True/False)

相等:== 内容相同

子集:s1.issubest(s) #s1 是s的子集

超集:s1.issuperest(s)#s1是s的超集(母集)

交集:s1.isdisjoint(s)#s1和s是否有交集

|-&^并差交补

六:文件处理

1:读取:

file = open(打开函数)(‘a.txt(文件名)’,‘r’(只读模式))

print(file.readlines)#读取全部内容 列表形式

file.close(关闭)

2:编写

file = open(打开函数)(‘a.txt(文件名)’,‘w’(覆盖写模式,完全覆盖))

file.write(‘hello’)

file.close(关闭)

file = open(打开函数)(‘a.txt(文件名)’,‘w’(覆盖写模式,完全覆盖))

file.write(‘hello’)

file.close(关闭)

3:追加内容:

file = open(打开函数)(‘a.txt(文件名)’,‘a’(追加写模式,在文件最后追加内容))

file.write(‘hello’)

file.close(关闭)

4:二进制模式

‘b’:不单独使用 ,通常和r或w一起。

5:常用方法:

filr.read([size]) 从文件中读取size个字节或字符的内容返回,若省略[size],则读取到末尾
file.readline() 读取一行内容
file.readlines() 以列表形式返回每一行
file.write(str) 将字符串str内容写入文件
file.writrlines(s_list) 将字符串s_list写入文本 不添加换行符
file.seek(offset[,whence]) 将文件指针移动到新的位置{
offset 为正 正向移动 为负 负向移动
whence :0:文件头 1:当前位置 2:文件尾
}
file.tell():返回指针当前位置
file.close() 关闭文件

七:sorted 函数

sorted(a) a 可以是元组、列表、集合、字符串、字典

八:map

a,b=map(int,input("请输入2个数字(用空格隔开)").split())

九:结巴库

import jieba
#精确模式
jieba.lcut(s)
#全模式
jieba.lcut(s,cut_all=True)
#搜索引擎模式
jieba.lcut_for_search(s)
#增加新词
jieba.add_word(w)

十:string库

十一:math库

十二:turtle库

turtle.pensize() #画笔粗细
turtle.color('red') #画笔颜色
turtle.speed() #画笔移动速度 画笔绘制的速度范围[0,10]整数,数字越大越快

turtle.forward() #向前移动
turtle.backward() #向后移动
turtle.right(90) #海龟方向向右转90°
turtle.left(90) #海龟方向向左转90°

turtle.penup() #提笔
turtle.pendown() #落笔

turtle.goto(x,y) #移动到(x,y)位置
turtle.setx(x) #x坐标移动到指定位置
turtle.sety(y) #y坐标移动到指定位置

turtle.circle() #画圆
turtle.dot() #画一个圆点(实心)

turtle.setheading(angle) #设置当前朝向为angle角度
turtle.home() #设置当前画笔位置为原点,朝向东(默认值)

turtle.fillcolor('red') #填充颜色
turtle.color(color1, color2) #设置 画笔颜色为color1,填充颜色为color2

turtle.begin_fill() #开始填充颜色
turtle.end_fill() #填充完成

turtle.hideturtle() #隐藏海龟图标
turtle.showturtle() #显示海龟图标

turtle.clear() #清空turtle窗口,但是turtle的位置和状态不会改变
turtle.reset() #清空turtle窗口,重置turtle状态为起始状态

turtle.undo() #撤销上一个turtle动作
turtle.isvisible() #返回当前turtle是否可见

t.write("文本" ,align="center",font=("微软雅黑",20,"normal")) #写文本
#align(可选):left,right,center;font(可选):字体名称,字体大小,字体类型(normal,bold,italic)

十三:with as :

with(上下文管理器):自动管理上下文资源

十四:类(Class)

类是模板,而实例则是根据类创建的对象

是面向对象最重要的概念之一:

例如半径是圆的实例属性 pi是圆的类属性

定义类使用class关键字,class后面加类名

进入类定义时,就会创建一个新的命名空间,并把它用作局部作用域,因此函数定义会绑定到这个局部作用域中。通过定义一个特殊的__init__方法,在创建实例的时候,就把name,score等属性绑定。

注意:我们定义的类都会继承于object类,当然也可以不继承object类;两者区别不大,但没有继承于object类使用多继承时可能会出现问题。

class Circle(object): # 创建Circle类
def __init__(self, r): # 初始化一个属性r(不要忘记self参数,他是类下面所有方法必须的参数)
self.r = r # 表示给我们将要创建的实例赋予属性r赋值

十五:CSV文件

逗号分隔值(Comma-Separated Values,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。

csv文件是通用数据处理经常所使用的数据交换文件。其原理是用逗号来分隔数据。

excel及各种数据库软件均支持csv文件的导入和导出。

eg:

以CSV的格式保存

import csv
csvFile = open("","r")#
reader = csv.reader(csvFile)
a = list(reader)
print(a)

十六:numpy库

import numpy as np

# np.array([x,y,z],dtype=int)#从python了列表和元组创造数组
# np.arange(x,y,i)#创建从x到y,步长为i的数组
# np.linspace(x,y,n)#创建从x到y,等分成n个元素的数组
# np.indices((m,n))#创建矩阵
# np.random.rand(m,n)#创建一个随机矩阵
# np.ones((m,n),dtype)#创建一个m行n列的全是1的数组
# np.empty((m,n),dtype)#创建一个m行n列的全是0的数组

a = np.ones((4,5))
print(a)
print(a.ndim)
#创建数组后,可以查看ndarray的基本属性

print(a.ndim)#数组轴的个数,也叫秩 2
print(a.shape)#数组在每个维度上的整数元组 (4,5)
print(a.size)#数组元素的总个数
print(a.dtype)#数据类型 dtype('float64')
print(a.itemsize)#数组中每个元素的字节大小
print(a.data)#包含实际数组元素的缓冲区地址
print(a.flat)#数组元素的迭代器


十六:pandas库

pandas是提高性能易用数据类型和分析工具,常与numpy和matplotlib一起用

import pandas as pd

包含两个数据类型:series(一维)dataframe(二维)

这篇关于T03.python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060757

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核