python语言基础

python语言基础

第一章 你好python

1.1安装python

https://www.python.org/downloads/release/python-3104/

image-20240412085450853

自定义安装,全选

image-20240412085532270

配置python的安装路径

image-20240412085713867

验证:cmd输入python

image-20240412085920434

1.2python解释器

image-20240412091106686

解释器主要做了两件事:

  1. 翻译代码
  2. 提交给计算机去运行

解释器就是这个python.exe

image-20240412091155948

在命令提示符中的python,就是调用了这里的python.exe解释器

1.3pycharm安装

https://blog.csdn.net/weixin_59047731/article/details/135634418

https://www.jetbrains.com/pycharm/download/other.html

1.4pycharm基础使用

1.4.1更改主题

image-20240412101608696

1.4.2更改字体大小

setting->Editor->font

image-20240412101745265

设置增加的快捷键 ctrl+鼠标上滚轮,缩小输入decrease

image-20240412102004299

1.4.3安装中文语言包

image-20240412102441669

1.4.4安装翻译软件

输入translation

image-20240412102714929

1.4.5常用快捷键

image-20240412105608597 image-20240422084352880

在方法上按住ctrl+p可以查看参数

image-20240423154000179

第二章 python基础语法

2.1 字面量

字面量:被写下来的固定的值

6种值的类型

image-20240412141359013

字符串:又称为文本,是由任意数量的字符如中文、英文、各类符号、数字等组成。所以叫做字符的串。(凡是被引号包围起来的,统统都是字符串)

2.2 注释

单行 #

多行 """ """

2.3 变量

image-20240412142659178

2.4数据类型

type()

通过type(变量) 可以输出数据的类型,因为变量无11类型,但是他存储的数据有。

·

2.5 类型转换

image-20240412145046524

image-20240412153104035

2.6 标识符

大小写敏感

只能使用 中文 、数字 、下划线、英文字母。

不能以数字开头

不可使用关键字

image-20240412153624073

变量命名

  • 多个单词组合名,需要使用下划线做分割
  • 英文字母全小写

2.7 算数运算符

image-20240414102050352

除和整除的区别:除是小数,整除是取整

2.8字符串拓展

2.8.1 字符串的三种定义方式

可以使用三种定义:

  • 单引号
  • 双引号
  • 三引号

引号嵌套:

  • 可以使用:\ 来进行转义
  • 单引号内可以写双引号,或者双引号内可以写单引号

2.8.2 字符串拼接

使用 “+”号连接字符串变量或者字符串字面量即可

其他类型不能使用加号和字符串拼接

image-20240415204422766

2.8.3 字符串格式化

%s

  • %表示:我要占位
  • s 表示:将变量变成字符串放入占位的地方

多个变量占位,变量要用括号括起来,并且按照占位的顺序填入

2.8.4 格式化的精度控制

1.m.n

  • m 控制宽度,要求是数字(很少使用)

  • n控制小数点精度,会进行小数的四舍五入

image-20240415214200362

2.f“{占位}

#f:format
print(f"我是{name},我的歌曲:{song},今年{age}")
image-20240415215011675

2.8.5 对表达式进行格式化

表达式:一条具有明确执行结果的代码语句

image-20240415215754341

2.9 数据输入

input()接收的所有类型都是字符串,如果你想转换为其他类型可以自行转换

第三章 python 判断语句

3.1布尔类型和逻辑运算符

image-20240416104316309 image-20240416104457646

3.2 if语句的基本格式

1.基本格式:

if 判断条件:
    条件成立要执行的语句
else:
    

2.注意:

  • 判断条件结果一定是bool类型
  • 不要忘记判断条件后的:
  • 归属于if语句的代码块,需要在前方填充4个空格缩进
image-20240416193724827

3.3 if elif else语句的基本格式

  1. if elif else 语句可以用来完成多个条件的判断

  2. 注意点:

    elif可以写多个

    判断是互斥并且有序的,上一个满足后面的就不会判断了

    可以在条件判断中,直接写input语句,节省代码量

第四章 python 循环语句

4.1while循环的基础应用

image-20240417181949745

4.2 while 循环的基础案例

添加一个end=' ',可以不换行

print("world",end='')

\t效果等同于在键盘上按下 tab键

打印九九乘法表

# 定义外层循环的控制变量
i = 1
while i<=9:
    # 控制里面每一行的内容输出
    j = 1
    while j<=i:
        print(f"{j}*{i}={j*i}\t",end='')
        # print("%d * %d=" %(j,i),j*i,"\t",end='')
        j+=1
    i+=1
    print("")

4.3 for循环的基础使用

for 变量 in 被处理的数据

同while循环不同,for循环是无法定义循环条件的

只能从被处理的数据集中,依次取出内容进行处理

4.4 range 语句

for循环语句本质上是遍历:序列类型

语法1:

range(num)

获取一个从0开始,到num结束的数字序列,不包括num本身(默认从0开始)

比如range(5)取得的数据是[0,1,2,3,4]

语法2:

range(num1,num2)

获取一个从num1开始到num2结束的数字序列,不包括num2本身

语法3:

range(num1,num2,step)

获得一个从num1开始,到num2结束的数字序列(不包括num2本身),step默认为1

range(5,10,2)所取得的数据是:[5,7,9]

image-20240421093507450

4.5 for循环的嵌套应用

打印99乘法表

for x in range(1,10):
    for y in range(1,x+1):
        print(f"{x}*{y} = {x*y}\t",end='')
    print("")

4.6 continue关键字

image-20240421100356780

continue关键字只可以控制他所在的循环临时中断

4.7 break关键字

break关键字可以用于直接结束循环,直接循环就全部结束

import random
money = 8000
for x in range(1,21):

    grade_point = random.randint(1,10)
    if grade_point<5:
        print(f"员工{x},绩效分{grade_point},低于5,不发工资,下一位")
        continue
    else:
        if money <= 0:
            print("工资发完了,下个月吧")
            break
        print(f"向员工{x},发放工资1000元,账户余额还剩{money-1000}")
        money -= 1000

第五章 python函数

5.1 函数基础用法

函数:可复用的代码段

函数的定义:

def 函数名(传入参数)
	函数体
    return 返回值

函数的调用:

函数名(参数)

注意:

  1. 参数和返回值可以省略
  2. 函数必须先定义后使用

变量可以接收函数的返回值:

变量 = 函数(参数)

5.2 None类型

None:表示这个函数没有返回有意义的内容,就是返回空的意思

如果我们的函数没有使用return语句来返回数据:函数有返回值

image-20240421112617173

1.可以用在函数无返回值上:

def say_hi():
    print("你好呀~")
    return None

2.和if搭配:None在if判断中表示false的意思,故可以通过if去判断返回值

if not status:
    # 能够进入if表示status是none值
    print("未成年人 不可以进入网吧")

3.用在无内容的变量上:定义了一个变量但是暂时不需要有具体值,可以用None来代替

name = None

5.3 函数说明

在函数最开始的时候敲"""回车pycharm会自动生成

# 定义函数,进行文档说明
def add(x,y):
    """
    add函数可以接收两个参数,进行两数相加的功能
    :param x:形参x表示相加的其中一个数字
    :param y:形参y表示相加的另一个数字
    :return:返回值是2数相加的和
    """
    result = x+y
    return result

在pycharm调用之后将鼠标悬停,可以看到相关的注释

image-20240421125036764

5.4 嵌套调用

def func_b():
    print("---b---")

def fun_abc():
    print("---a---")
    func_b()
    print("---c---")
fun_abc()

5.5 函数的作用域

局部变量:作用范围定义在函数内部,在函数外部无法使用

全局变量:在函数的外部定义的变量,在函数的内部可以使用,在函数的外部也可以使用

可以通过global关键字将函数内定义的变量声明为全局变量

def test_a():
    print("test_a",{num})
def test_b():
    # 通过global关键字声明a是一个全局变量
    global num
    num = 500 #局部变量
    print("test_b:",{num})
test_a()
test_b()
print(num)

5.6 综合案例

银行ATM机

name = None
money = 100

name = input("请输入您的名字:")

def query(show_header):
    if show_header:
        print("--------------查询余额--------------")
    print(f"您好~{name}的余额剩余:{money}元")
def save(carry):
    global money
    money = money + carry
    print(f"存完了,你现在剩余余额为{money}")
    query(False)
def get_money(carry):
    global money
    flag = True
    while flag:
        carry = int(input("请输入您要取的金额:"))
        if carry > money:
            print("钱不够,请修改余额")
        else:
            flag = False

            money = money - carry
            query(False)
def show(name):
    outFlag = True
    while outFlag:
        print("--------------主菜单--------------")
        print(f"你好~{name},欢迎来到ATM,请选择操作:")
        print("查询余额\t[输入1]")
        print("存款\t[输入2]")
        print("取款\t[输入3]")
        print("退出\t[输入4]")
        choice = int(input("请输入您的选择:"))
        if choice == 1:
            query(True)
        elif choice == 2:
            print("--------------存款--------------")
            carry = int(input("请输入您要存的金额:"))
            save(carry)
        elif choice ==3:
            print("--------------取款--------------")
            carry = None
            get_money(carry)
        elif choice == 4:
            print("--------------退出--------------")
            outFlag = False
        else:
            print("您输入的数字不合法,请重新输入")
show(name)

第六章 python数据容器

数据容器:一种可以存储多个元素的数据类型

image-20240421184322743

image-20240421184339359

image-20240422083411451

6.1 列表list

6.1.1列表定义

image-20240421140655240

6.1.2列表的下标索引

image-20240421141145641

反向索引:

image-20240421141237215

嵌套的列表:

image-20240421141444005

6.1.3 列表的常用操作

image-20240421145215798

1.列表的查询功能:

功能:查找指定元素在列表中的下标,如果找不到,报错ValueError

列表.index(元素)

2.列表的修改

列表[元素下标] = 值

3.插入元素

列表.insert(下标,元素)

4.追加元素到尾部

列表.append(元素)

5.追加一批元素

列表.extend(元素)

6.删除元素

按照下标删除

  • 语法1:

    del 列表[下标]
    
  • 语法2:

    列表.pop(下标)
    

按照元素的内容删除(只能删除第一个匹配项)

列表.remove()

7.清空列表

列表.clear()

8.统计列表中元素的数量

列表.count()

9.统计列表中全部的元素数量

len(列表)

6.1.4 列表的特点

image-20240421145348464

6.1.5列表的遍历

可以使用while或者for循环

count = 0
list = ['a', 'b', 'c']
while count<len(list):
    print(list[count])
    count += 1
for x in range(len(list)):
    print(list[x])

不同点:

  • while比较自由,for只能一个个的从list里面取元素
  • while可以无限循环,只要count每次不加1
  • while通用,for适用于简单的想要遍历所有的元素和固定次数

6.2 元组tuple

元组可以看作是一个只读的list,不可修改

6.2.1元组的定义

image-20240421153824913

定义单个元素的时候一定要在后面写上一个逗号,否则就不是元组了

6.2.2 元组的方法

image-20240421154756747 image-20240421160610312

6.3 字符串str

字符串是字符的容器,一个字符串可以存放任意数量的字符

6.3.1 字符串的常见方法

image-20240421164257422

同其他容器一样,字符串可以通过下标访问

  • 从前向后,下标从0开始
  • 从后向前,下标从-1开始

字符串是一个不可修改的数据容器

1.查找某个字符串在这个字符串中的起始位置

字符串.index表示可以查找这个字符串起始字母所在位置

2.字符串的替换

可以将字符串1全部替换为字符串2,这里并不是修改字符串本身,而是得到了一个新的字符串

字符串.replace(字符串1,字符串2)

3.字符串的分割

按照指定的分隔符字符串,将字符串划分为多个字符串,并存入到列表对象中。这里是字符串本身不变,得到了一个列表对象

字符串.split(分隔符字符串)

4.字符串的规整操作(去掉前后空格)

  • 不传入参数默认就是把头和尾的空格去除
字符串.strip()
  • 传入参数,就将其传入的参数划分为单个字母的小子串,然后首尾去除相应的内容

5.统计字符串中某个字符串出现的次数 count

字符串.count("所要统计的字符串")

6.统计字符串的长度

len(字符串)

6.3.2字符串 的特点

image-20240421164344948

6.4数据容器的切片

6.4.1 序列的定义

序列:内容连续,有序,可以使用下标索引的一类数据容器

列表、元组、字符串都可以看作是序列

6.4.2 序列的常用操作

切片:从一个序列中,取出一个子序列

序列[起始下标:结束下标:步长]
  • 起始下标不写视作从头
  • 结束下标(不含),可以留空,留空视作截取到结尾
  • 步长:一次取元素的间隔大小
    • 步长为1,一个个的取元素
    • 步长为2,每次跳过1个元素取
    • 步长为n,每次跳过n-1个元素取
    • 步长为负数表示反向区

对序列进行切片操作并不会影响到序列本身,而是会得到一个新的序列。(因为元组和字符串都是不支持修改的)

my_list = [1, 2, 3, 4, 5]
new_my_list = my_list[::-1] # 等同于将数列反转了

如果步长是负的,那么需要起始下标需要从尾部开始,终止下标需要从头部结束

my_str = ("123456")
new_my_str = my_str[6:1:-2]

6.2.3 序列的案例

str1 = "万过薪月,员序程马黑来,nohtyP学"
# 倒序字符串 ,切片取出
newstr = str1[5:10:]
newstr2 = newstr[::-1]
print(newstr2)

#切片取出 倒序
newstr3 = str1[::-1][9:14:1]
print(newstr3)

#split分割 replace
newstr4 = str1.split(",")[1].replace("来",'')[::-1]
print(newstr4)

6.5 集合set

image-20240421172304350

6.5.1集合的定义

image-20240421172406038

image-20240421172414841

如果想定义一个空集合只能使用 set(),不能使用set={},这种写法被字典占用了

6.5.2集合的方法

因为集合是无序的,所以集合不支持:下标索引访问

但是集合和列表一样,是允许修改的

image-20240421174442548

pop() 如果都是数字会自动排列 顺序,pop取的是0号元素。但是字符串是随机排列的

difference_update :消除两个集合的差集 调用者的集合被修改删掉了相同的元素

# 集合的遍历
# 集合不支持下标索引,不能用while循环
# 可以用for循环
set1 = {1,2,3,4,5,6,7,8,9}
for i in set1:
    print(i)

6.5.3集合的特点

image-20240421174748431

6.6 字典dict

6.6.1 字典的定义

image-20240421175542319

注意事项:

  • 字典中的key是不允许重复的,新的会将旧的覆盖掉
  • key和value可以是任意类型
dict1 = {"周杰伦":"稻香","陶喆":"流沙","陈奕迅":"爱是一本书"}
print(dict1)
# 定义空字典
dict2 = dict()
dict3 = {}
# 定义重复的Key的字典
dict4 = {"周杰伦":"稻香","周杰伦":"流沙","陈奕迅":"爱是一本书"}
print(dict4)
print(dict1['周杰伦'])
# 定义嵌套字典
stu_score_dict={
    "小红":{
        "语文":99,
        "数学":100,
        "英语":98
    },
    "小王":{
        "语文": 100,
        "数学": 100,
        "英语": 100
    }
}
print(stu_score_dict['小王']['语文'])

6.6.2 字典的方法

image-20240421183104939

dict1 = {"周杰伦":"稻香","陶喆":"流沙","陈奕迅":"爱是一本书"}
# 新增
dict1["方大同"] = "三人行"
print(dict1)
# 更新元素
dict1["周杰伦"] = "暗号"
print(dict1)
# 删除元素 结果获得指定值的value
song = dict1.pop("周杰伦")
print(song)
print(dict1)
# 清空字典
dict1.clear()
print(dict1)
# 获取全部的key
dict2 = {"周杰伦":"稻香","陶喆":"流沙","陈奕迅":"爱是一本书"}
keys = dict2.keys()
print(keys)

#遍历字典
# 方式1:通过获取到的全部的key来完成遍历
for key in keys:
    print(dict2[key])
# 方式2:直接对字典进行for循环,每一次循环都是直接得到key
for key in dict2:
    print(dict2[key])

# 统计字典的元素数量
print(len(dict2))

6.6.3 字典的特点

image-20240421183212583

6.7 总结

数据容器的通用操作:

  1. 遍历
    • 五类数据容器都支持for循环遍历
    • 列表、元组、字符串都支持while循环,集合、字典不支持(无法下标索引)
  2. len(容器)
  3. max(容器)统计容器的最大元素
  4. min(容器) 统计容器的最小元素
  5. 类型转换
image-20240422084605796

字典转其他,key保留,value舍弃

image-20240422090917783

排序的结果会统统变为列表对象,将内容排序放入列表之中

reverse=True说明是降序

image-20240422092842967

6.8 拓展 字符串大小比较

image-20240422093230198 image-20240422093411998

第七章 python 进阶

7.1函数

7.1.1函数的多返回值

image-20240422100710385

7.1.2函数传参方式

image-20240422101101416

image-20240422101227882

关键字参数传参的时候可以不按照参数的定义顺序传参

位置参数和关键字参数混用的时候,位置参数必须在关键字参数的前面

image-20240422102044991

设置默认值的时候,必须要统一的都在最后

image-20240422102445429

image-20240422102513548

"""
演示多种传参的形式
"""
# 位置参数 默认使用形式
def user_info(name,age,gender):
    print(f"姓名是{name},年龄是{age},性别是{gender}")
user_info("周杰伦",46,'男')

# 关键字参数
user_info(name = '小王',age = 11,gender='女')
user_info(age = 11,name = '小丽',gender='女')
user_info('陶喆',age=100,gender='男')
# 缺省参数(默认值)
def user_info(name,age=20,gender='男'):
    print(f"姓名是{name},年龄是{age},性别是{gender}")
user_info("周杰伦",46,'男')
user_info("林俊杰")

# 不定长 位置不定长 *号
# 不定长定义的形式参数会作为元组存在,接收不定长数量的参数传入
def user_info(*args):
    print(f"args参数的类型是:{type(args)} 内容是:{args}")
user_info("孙燕姿",'雨天',11)
# 不定长 关键字不定长 **号
def user_info(**kwargs):
    print(f"args参数的类型是:{type(kwargs)} 内容是:{kwargs}")
user_info(song="雨天",singer='孙燕姿')

7.1.3 匿名函数

1.函数的传入形式

函数本身也可以作为参数传入到另一个函数内

普通的函数:数据不确定,具体的运算逻辑在函数体内写好了

函数的传入形式:被计算的数据是确定的,不确定的是计算数据的逻辑

def compute(x,y):
    return x+y
def funcompute(compute):
    result = compute(2,3)
    print(f"compute函数的类型是:{type(compute)}")
    print(result)
funcompute(compute)

2.lambda匿名函数

image-20240422105238460

lambda无法去写多行

def test_func(compute):
    result = compute(1,2)
    print(f"结果是{result}")
# 通过lambda匿名函数的形式,将匿名函数作为参数传入
test_func(lambda x,y:x+y)

第八章 python文件操作

8.1文件的读取操作

1.open() 打开函数

image-20240422111706967

mode常用的三种基础访问模式:

  • r 以只读的方式打开文件,文件的指针会放在文件的开头。这是默认模式
  • w 打开一个文件只用于写入,如果该文件已经存在则打开文件,并从开头开始编辑,原有的内容会被删除,如果该文件不存在,则创建新文件
  • a 打开一个文件用于追加,如果这个文件已经存在,那么新的内容将会被写入到已有内容之后,如果这个文件不存在,创建新文件进行

TextIOWrapper是对文本文件进行IO操作功能的一个类

2.read()读操作

image-20240423091252902

如果在程序中多次调用read,上一次read会在下一次read的结尾处接着读取

image-20240423093948392

image-20240423094114638

image-20240423095358174

8.2 文件读取的小案例 统计字符

# 方式1
f = open("word.txt","r",encoding="utf-8")
 content = f.read()
 print(content)
 count = content.count("itheima")
 print(count)

# 方式2
count = 0
for line in f:
    line = line.strip()
    words = line.split(" ")
    for word in words:
        if word == 'itheima':
            count = count + 1
print(count)
f.close()

strip 可以去除字符串开头和结尾的空格以及换行符

8.3文件的写入操作

image-20240423102024142

文件不存在w模式是帮你创建文件

当文件已经存在的时候,你再用write会将里面的内容全部清空

"""
演示文件的写入
"""
import time

#打开文件,不存在的文件
f = open("test.txt","w",encoding="utf-8")
# write 写入
f.write("Hello World!") #将内容写入到内存中
# flush 刷新
#f.flush()   # 将内存中积攒的东西,写入到硬盘的文件中

# close 关闭
f.close() # close方法是内置了flush的功能


# 打开一个存在的文件
f = open("test.txt","w",encoding="utf-8")
# write写入 flush刷新
f.write("柳絮飘")
# close 关闭
f.close()

8.4 文件的追加操作

image-20240423103642291

8.5 文件操作的综合案例

name,date,money,type,remarks
周杰轮,2022-01-01,100000,消费,正式
周杰轮,2022-01-02,300000,收入,正式
周杰轮,2022-01-03,100000,消费,测试
林俊节,2022-01-01,300000,收入,正式
林俊节,2022-01-02,100000,消费,测试
林俊节,2022-01-03,100000,消费,正式
林俊节,2022-01-04,100000,消费,测试
林俊节,2022-01-05,500000,收入,正式
张学油,2022-01-01,100000,消费,正式
张学油,2022-01-02,500000,收入,正式
张学油,2022-01-03,900000,收入,测试
王力鸿,2022-01-01,500000,消费,正式
王力鸿,2022-01-02,300000,消费,测试
王力鸿,2022-01-03,950000,收入,正式
刘德滑,2022-01-01,300000,消费,测试
刘德滑,2022-01-02,100000,消费,正式
刘德滑,2022-01-03,300000,消费,正式

将正式数据写入备份

"""
演示文件操作综合案例:文件备份
"""
f = open("bill.txt","r",encoding="utf-8")
f2 = open("bill.txt.bak","w",encoding="utf-8")
for line in f:
    newline = line.strip().split(',')
    print(newline)
    if newline[4] == "正式":
        f2.write(line)
        f2.write("\n")
f.close()
f2.close()


第九章 python异常、模块与包

9.1 异常的捕获

image-20240423105506745 image-20240423105543519 image-20240423110016050 image-20240423111431648

image-20240423111834824

# 基本捕获语法
try:
    f = open('test111.txt','r')
except:
    f = open('test.txt','w')
# 捕获指定的异常
try:
    print(name)
    # 1/0
except NameError as e:
    print("出现了变量未定义的异常")
    print(e)
# 捕获多个异常
try:
    # print(name)
    1/0
except (ZeroDivisionError,NameError) as e:
    print("出现了变量未定义的异常 或者除以0的异常错误")
    print(e)
#捕获所有异常
try:
    # 1/0
    print(1)
    f = open('test2.txt','r')
except Exception as e:
# 或者直接写 except: 起到同样的效果
    print("出现异常了")
    print(e)
    f = open('test2.txt','w')
else:
    print("没有出现异常")
finally:
    f.close()

9.2 异常的传递

image-20240423112625924

# 定义一个出现异常的方法
def func01():
    print("这是func01开始")
    num = 1/0
    print("这是func01结束")
# 定义一个没有异常的方法 调用上面的方法
def func02():
    print("这是func02开始")
    func01()
    print("这是func02结束")
# 定义一个方法,调用上面的方法

def main(): #异常在main中被捕获
    try:
        func02()
    except Exception as e:
        print(e)
main()

9.3 模块

image-20240423112842231

image-20240423112900721
# 使用import 导入time 模块使用sleep
import time # 导入python内置的time模块
print("你好")
time.sleep(2)
print("hi")
#只使用time中的sleep
from time import sleep
print("你好")
sleep(2)
print("hi")
# 使用 * 导入time模块的全部功能
from time import *
print("你好")
sleep(2)
print("hi")
# 使用as给指定功能加上别名
import time as t
t.sleep(2)
from time import sleep as sl
sl(2)

image-20240423130056955

image-20240423131221105

内置变量__name__右键运行的时候,会将这个值设置为__main__

image-20240423131122600

# 导入自定义模块使用
# import my_module
# my_module.test(1,2)

#导入不同模块的同名功能
from my_module import test
from my_module2 import test
test(3,1)
# __main__变量
from my_module import test
# __all__变量
from my_module import *
test_a()
# test_b() 但是此时可以用import指定的名字导入
from my_module import test_b

my_module的内容:

__all__ = ['test_a']

# 演示自定义模块
def test(a,b):
    print(a+b)
if __name__=='__main__':
    test(1, 2)
def test_a():
    print("a+b")
def test_b():
    print("a-b")

9.4 python包

9.4.1 python自定义包

基于python模块,我们可以在编写代码的时候,使用很多外部代码来丰富功能,但如果python模块太多了,可能会造成一定的混乱

image-20240423132246595

有这个__init__.py就是一个python包,没有的话就是一个普通的文件夹而已

# 创建一个包
# 导入自定义的包中的模块,并使用
import my_package.my_module1
import my_package.my_module2

my_package.my_module1.test(1,2)
my_package.my_module2.test(1,2)

from my_package import my_module1
from my_package import my_module2
my_module1.test(1,2)
my_module2.test(1,2)

from my_package.my_module1 import test
from my_package.my_module2 import test

# 通过__all__变量,控制import * 在__init__.py中写
from my_package import *
my_module1.test(1,2)
# my_module2.test(1,2)
image-20240423133403065

9.4.2 python 安装第三方包

  • 在命令提示符中
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple numpy
  • 在pycharm中

在pycharm中点击interpreter settings

image-20240423134031357

image-20240423134255074

9.5 自定义工具包

image-20240423140432728

file_util.py

def print_file_info(fname):
    f = None
    try:
        f = open(fname, 'r', encoding='utf-8')
        content = f.read()
        print(content)
    except:
        print("文件不存在")
    finally:
        if f:   # 如果变量是None,表示false,如果有任何内容,就是True
            f.close()

def append_to_file(fname, data):
    f = open(fname, 'w', encoding='utf-8')
    f.write(data)
    f.write("\n")
    f.close()

if __name__ == '__main__':
   # print_file_info("word.txt")
    append_to_file('words.txt','123')

str_util.py

def str_reverse(s):
    return s[::-1]
def substr(s,x,y):
    return s[x:y]

if __name__ == '__main__':
    print(str_reverse('hello'))
    print(substr('hello',0,2))

第十章 python基础综合案例

10.1数据可视化-折线图可视化

10.1.1 json数据格式

image-20240423150307201

json的格式数据转化:

image-20240423150536320

  • 要么是一个字典
  • 要么是列表里面嵌套了字典

image-20240423150649437

image-20240423150732591

"""
演示json数据和python字典的相互转化
"""
# 准备列表,列表内部每一个元素都是字典,将其转化为json
import json
data = [{"name":"周杰伦","age":47},{"name":"林俊杰","age":40},{"name":"孙燕姿","age":30}]
json_str = json.dumps(data, ensure_ascii=False)
print(json_str)
print(type(json_str))
# 准备字典,将字典转换为json
d = {"name":"周杰伦","age":47}
json_str = json.dumps(d, ensure_ascii=False)
print(json_str)
# 将json字符串转换为python数据类型[{k:v,k:v},{k:v,k:v}]
s = '[{"name":"周杰伦","age":47},{"name":"林俊杰","age":40},{"name":"孙燕姿","age":30}]'
l = json.loads(s)
print(l)
print(type(l))
# 将json字符串转换为python数据类型{k:v,k:v}
s = '{"name":"周杰伦","age":47}'
d = json.loads(s)
print(d)
print(type(d))

10.1.2 pycharts的入门使用

image-20240423152544497
from pyecharts.charts import Line
#创建一个折线图对象
line = Line()
#给折线图对象添加x轴的数据
line.add_xaxis(['中国','美国','法国'])
#给折线图对象添加y轴的数据
line.add_yaxis('GDP',[10,2,6])
# 通过render方法,将代码生成为图像
line.render()
image-20240423153527077 image-20240423153544617 image-20240423154838166
from pyecharts.charts import Line
from pyecharts.options import TitleOpts, LegendOpts, ToolboxOpts, VisualMapOpts

#创建一个折线图对象
line = Line()
#给折线图对象添加x轴的数据
line.add_xaxis(['中国','美国','法国'])
#给折线图对象添加y轴的数据
line.add_yaxis('GDP',[10,2,6])
#设置全局配置项
line.set_global_opts(
    title_opts=TitleOpts(title = "GDP显示",pos_left="center",pos_bottom="1%"),
    legend_opts=LegendOpts(is_show=True),
    toolbox_opts=ToolboxOpts(is_show=True),
    visualmap_opts=VisualMapOpts(is_show=True),
)

# 通过render方法,将代码生成为图像
line.render()

10.1.3生成折线图

"""
演示可视化需求:折线图开发
"""
import  json
from pyecharts.charts import Line
from pyecharts.options import TitleOpts, LabelOpts

# 处理数据
f_us = open("折线图数据/美国.txt", "r", encoding="utf-8")
us_data = f_us.read()
f_india = open("折线图数据/印度.txt", "r", encoding="utf-8")
india_data = f_india.read()
f_japan = open("折线图数据/日本.txt", "r", encoding="utf-8")
japan_data = f_japan.read()
#去掉不合json规范的开头
us_data = us_data.replace("jsonp_1629344292311_69436(","")
india_data = india_data.replace("jsonp_1629350745930_63180(","")
japan_data = japan_data.replace("jsonp_1629350871167_29498(","")
#去掉不和json规范的结尾
us_data = us_data[:-2]
india_data = india_data[:-2]
japan_data = japan_data[:-2]
# json转python字典
us_dict = json.loads(us_data)
india_dict = json.loads(india_data)
japan_dict = json.loads(japan_data)

# 获取trend key
us_trend_data = us_dict['data'][0]['trend']
india_trend_data = india_dict['data'][0]['trend']
japan_trend_data = japan_dict['data'][0]['trend']
# 获取日期数据,用于x轴,取2020年
us_x_data = us_trend_data['updateDate'][:314]
india_x_data = india_trend_data['updateDate'][:314]
japan_x_data = japan_trend_data['updateDate'][:314]
# print(x_data)
# 获取确认数据,用于y轴,取2020年
us_y_data = us_trend_data['list'][0]['data'][:314]
india_y_data = india_trend_data['list'][0]['data'][:314]
japan_y_data = japan_trend_data['list'][0]['data'][:314]
# print(y_data)
# 生成图表
line = Line()           #构建折线图对象

# 添加X轴数据
line.add_xaxis(us_x_data) #x轴是公用的,所以使用一个国家的数据即可
# 添加Y轴数据
line.add_yaxis("美国确诊数据",us_y_data,label_opts=LabelOpts(is_show=False))
line.add_yaxis("印度确诊数据",india_y_data,label_opts=LabelOpts(is_show=False))
line.add_yaxis("日本确诊数据",japan_y_data,label_opts=LabelOpts(is_show=False))

line.set_global_opts(
    title_opts=TitleOpts(title="2020年美日印三国确诊人数对比折线图",pos_left="center",pos_bottom="1%")
)
# 生成图表
line.render()
# 关闭文件
f_us.close()
f_india.close()
f_japan.close()

10.2数据可视化-地图

10.2.1 全国疫情地图

import json
from pyecharts.charts import Map
from pyecharts.options import *
# 读取数据文件
f = open("地图数据/疫情.txt","r",encoding="utf-8")
province_data = f.read()
# 关闭文件
f.close()
# 取到各省数据
province_dict = json.loads(province_data)
province_data_list = province_dict['areaTree'][0]['children']
# 组装每个省份和确诊人数为元组,并每个省的数据都封装入列表内
data_list = []
for data in province_data_list:
    province_name = data["name"]
    province_confirm = data["total"]["confirm"]
    data_list.append((province_name,province_confirm))
# 创建地图对象
map = Map()
# 添加数据
map.add("全国疫情数据",data_list,"china")
# 设置全局配置,定制分段的视觉映射
map.set_global_opts(
    title_opts=TitleOpts(title="全国疫情地图"),
    visualmap_opts=VisualMapOpts(
        is_show=True,#是否显示
        is_piecewise=True,#是否分段
        pieces=[
            {"min": 1, "max": 9, "label": "1-9", "color": "#CCFFFF"},
            {"min": 10, "max": 99, "label": "10-99", "color": "#FFFF99"},
            {"min": 100, "max": 499, "label": "100-499", "color": "#FF9966"},
            {"min": 500, "max": 999, "label": "500-999", "color": "#FF6666"},
            {"min": 1000, "max": 9999, "label": "1000-9999", "color": "#CC3333"},
            {"min": 10000, "label": "10000以上", "color": "#990033"}
        ]
    )
)
# 绘图
map.render("全国疫情地图.html")

10.2.2 河南疫情地图

import json
from pyecharts.charts import Map
from pyecharts.options import *
f = open("地图数据/疫情.txt",'r',encoding='utf-8')
f_data = f.read()
f.close()
f_dict = json.loads(f_data)
henan_data_list = f_dict['areaTree'][0]['children'][3]['children']


city_list = []
for city_data in henan_data_list:
    city_name = city_data['name']
    city_comfirm = city_data['total']['confirm']
    city_list.append((city_name,city_comfirm))
print(city_list)
map = Map()
map.add("河南省疫情地图",city_list,"河南")
map.set_global_opts(
    title_opts=TitleOpts(title="河南省疫情情况",pos_left="center",pos_bottom="1%"),
    visualmap_opts=VisualMapOpts(
        is_show=True,
        is_piecewise=True,
        pieces=[
            {"min": 1, "max": 9, "label": "1-9", "color": "#CCFFFF"},
            {"min": 10, "max": 99, "label": "10-99", "color": "#FFFF99"},
            {"min": 100, "max": 499, "label": "100-499", "color": "#FF9966"},
            {"min": 500, "max": 999, "label": "500-999", "color": "#FF6666"},
            {"min": 1000, "max": 9999, "label": "1000-9999", "color": "#CC3333"},
            {"min": 10000, "label": "10000以上", "color": "#990033"}
        ]
    )

)
map.render("河南省疫情地图.html")

10.3 数据可视化-柱状图

10.3.1 柱状图的基础使用

from pyecharts.charts import Bar
from pyecharts.options import *
# 使用Bar来构建基础柱状图
bar = Bar()
# 添加x y轴的数据
bar.add_xaxis(['中国','美国','英国'])
#设置数值标签在右侧显示
bar.add_yaxis("GDP",[200,100,120],label_opts=LabelOpts(position="right"))

#反转xy轴
bar.reversal_axis()

# 绘图
bar.render("基础柱状图.html")

10.3.2 时间线

from pyecharts.charts import Bar,Timeline
from pyecharts.options import *
from pyecharts.globals import ThemeType
# 创建3个柱状图
bar1 = Bar()
bar1.add_xaxis(['中国','美国','英国'])
bar1.add_yaxis("GDP",[200,100,120],label_opts=LabelOpts(position="right"))
bar1.reversal_axis()

bar2 = Bar()
bar2.add_xaxis(['中国','美国','英国'])
bar2.add_yaxis("GDP",[400,200,60],label_opts=LabelOpts(position="right"))
bar2.reversal_axis()

bar3 = Bar()
bar3.add_xaxis(['中国','美国','英国'])
bar3.add_yaxis("GDP",[900,300,200],label_opts=LabelOpts(position="right"))
bar3.reversal_axis()

# 构建时间线对象
timeline = Timeline({
    "theme": ThemeType.LIGHT
})
#在时间线内添加柱状图对象
timeline.add(bar1,"点1")
timeline.add(bar2,"点2")
timeline.add(bar3,"点3")

# 自动播放设置
timeline.add_schema(
    play_interval=1000,
    is_timeline_show=True, # 是否在自动播放的时候显示时间线
    is_auto_play=True,# 是否自动播放
    is_loop_play=True# 是否循环自动播放
)
# 绘图是用时间线对象绘图而不是bar对象了
timeline.render("基础时间线柱状图.html")

10.3.3 动态柱状图绘制

image-20240424123200379

import json
from pyecharts.charts import Timeline
from pyecharts.charts import Bar
# 读取数据
f = open("动态柱状图数据/1960-2019全球GDP数据.csv",'r',encoding='GB2312')
content = f.readlines() #结果是列表
f.close()
# 处理掉第一行的表头
content.pop(0)

data_dict={}
# 将每一行处理
for line in content:
    newline = line.split(',')
    year = int(newline[0])
    country = newline[1]
    gdp = float(newline[2]) # 可以将科学计数法转换为整数
    try:
        data_dict[year].append([country,gdp])
    except KeyError:
        data_dict[year] = []
# 创建时间线对象
timeline = Timeline()
# 排序年份
# print(data_dict)
# 直接for循环字典可能会乱掉
for year in data_dict:
    # 取出GDP前8的国家
    data_dict[year].sort(key = lambda element:element[1],reverse=True)
    top_8 = data_dict[year][:8]
    x_data = []
    y_data = []
    for country_gdp in top_8:
        x_data.append(country_gdp[0])
        y_data.append(country_gdp[1])
    # 构建柱状图
    bar = Bar()
    x_data.reverse()
    y_data.reverse()
    bar.add_xaxis(x_data)
    bar.add_yaxis("GDP(亿)", y_data)
    # 反转x轴和y轴
    bar.reversal_axis()
    timeline.add(bar,str(year))
# timeline设置
    timeline.add_schema(
        play_interval=1000,
        is_loop_play=True,
        is_auto_play=True,
        is_timeline_show=True
    )
    timeline.render("1960~2019年全球GDP前8国家02.html")


posted @ 2024-04-12 10:37  记录学习Blog  阅读(15)  评论(0编辑  收藏  举报