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(二维)

相关推荐
算法小白(真小白)2 小时前
低代码软件搭建自学第二天——构建拖拽功能
python·低代码·pyqt
唐小旭2 小时前
服务器建立-错误:pyenv环境建立后python版本不对
运维·服务器·python
007php0072 小时前
Go语言zero项目部署后启动失败问题分析与解决
java·服务器·网络·python·golang·php·ai编程
Chinese Red Guest2 小时前
python
开发语言·python·pygame
骑个小蜗牛3 小时前
Python 标准库:string——字符串操作
python
黄公子学安全5 小时前
Java的基础概念(一)
java·开发语言·python
程序员一诺6 小时前
【Python使用】嘿马python高级进阶全体系教程第10篇:静态Web服务器-返回固定页面数据,1. 开发自己的静态Web服务器【附代码文档】
后端·python
小木_.6 小时前
【Python 图片下载器】一款专门为爬虫制作的图片下载器,多线程下载,速度快,支持续传/图片缩放/图片压缩/图片转换
爬虫·python·学习·分享·批量下载·图片下载器
Jiude7 小时前
算法题题解记录——双变量问题的 “枚举右,维护左”
python·算法·面试