模块与包及json模块学习

2024-04-21 09:12
文章标签 模块 学习 json 包及

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

【一】模块与包介绍

【1】什么是模块

在Python中,一个py文件其实就是一个模块

文件名 knight.py中 py就是模块名

【2】模块的优点

有了模块以后可以增加程序的可读性,提高开发效率

【3】模块的来源

(1)在Python解释器内部内置有很多模块
(2)自己写的文件也是一个模块

【4】模块的存在形式

(1)单模块

就是自己定义的功能所在的py文件

(2)包

将自己定义的功能所在的py文件总结起来,放到一个文件夹下,构成一个包

必须有--init--.py文件

【二】模块的使用

# knight文件
name = "knight"
​
​
# 定义一个函数 函数的功能是打印name
def show_name():print(name)
​
​
# 定义一个函数修改name
def change_name():global namename = "hyt"# print(name)# 内嵌函数
def outer():def inner():print(f'这是outer内部的inner')return inner
  • 下面我又新建了一个文件,在新建文件中 ,导入上面的模块文件knight

import knight
# 打印当前 模块对象 位置
print(knight)
# 打印模块中的 name 值
print(knight.name)
# 调用模块中的更改name值的方法 修改全局的name
knight.change_name()
# 更新全局的name
print(knight.name)
# 调用内嵌函数
func = knight.outer()
func()

【2】import语句发生的内部原理

  • 前提是有一个自己写的 xxx.py 文件 在这个py文件内部有自己的名称空间

  • 通过import xxx 导入了当前模块

  • 进入到xxx.py 文件,将所有源代码执行一遍

  • 如果没有写调用函数的命令,则不会调用,而是检索到所有的函数地址

  • 会自动创建一个xxx.py文件的名称空间 --->将xxx.py 文件 的名称空间和 自己的名称空间合并

  • 通过模块名.属性名

【3】支持导入多个模块

(1)方式一:单独导入多个模块
import knight
import time
import user_src
(2)方式二:一次性导入多个模块
import knight, user_src, time

【4】详细导入语法

(1)只要模块中的指定参数或者方法
from 模块名 import 属性名
from knight import show_name
show_name()     
(2)只要模块中的所有参数和方法
from knight import *
show_name()
print(name)
outer = outer()
outer()

【5】重命名模块

  • 对导入的模块进行重命名

import numpy as np
# 导入模块 模块名叫 knight,但我改成gdy
from knight import name as gdy
# 在当前文件中执行gdy
print(gdy)      # knight

【三】循环导入问题

  • 在一个文件中调用另一个文件

  • 另一个文件再调用当前文件

【1】方法一

bar.py

print("正在导入foo")
name_bar = 'bar'
from foo import name_foo
print('导入foo结束')

foo.py

print('正在导入bar')
name_foo = 'foo'
from bar import name_bar
print('导入bar结束')

main.py

import bar

【2】方法二

  • foo.py

print('导入bar开始')
name_foo = 'foo'
def show_name_foo():from bar import name_barprint(name_bar)
print('导入bar结束')
  • bar.py

print('导入foo开始')
name_bar = 'bar'def show_name_bar():from foo import name_fooprint(name_foo)
print('导入foo结束')
  • main.py

import bar
bar.show_name_bar()

【四】模块加载和搜索顺序

【1】模块的分类

纯python编写的自己定义的模块

内置的一系列模块 (python解释器自带的和你安装 pip install )

使用c语言编写的底层代码

c 和 c++ 扩展出去的模块

【2】加载顺序

先c 和 c++ 扩展出去的模块

使用c语言编写的底层代码

内置的一系列模块 (python解释器自带的和自己安装的pip)

自己编写的定义的Python文件

【3】查找顺序

  • 先从自己的局部查

def func():import time
  • 再从全局查

import time 
  • 再去内建查

    • python解释器自带的模块和你安装的模块中查,查出对应的模块再使用

  • 去底层c语言查

    • 有些功能点进去看源码发现只有一个pass,是因为它使用c语言写的,但是被他省略了

【五】绝对路径和相对路径

【1】相对路径

# ./表示当前同级目录下
# ../表示当前目录的上一级目录
# 默认就是当前目录下
with open('../user_data.text', 'w', encoding='utf-8') as fp:fp.write('111'

【2】绝对路径

# 在python内部查找的顺序都是绝对
import sys
print(sys.path)
# [
# 'H:\\pycharm projects\\day\\模块学习',
# 'H:\\pycharm projects',
# 'H:\\Pycharm\\PyCharm 2023.3.5\\plugins\\python\\helpers\\pycharm_display',
# 'H:\\python\\python310.zip',
# 'H:\\python\\DLLs',		# 这里放的就是c语言源码编译后的扩展包
# 'H:\\python\\lib',		# 放的是内置的模块或者安装的模块
# 'H:\\python',				# # 安装python解释器的路径
# 'H:\\python\\lib\\site-packages',		# 这里面也有部分安装的的包 ,默认安装到 site-packages
# 'H:\\Pycharm\\PyCharm 2023.3.5\\plugins\\python\\helpers\\pycharm_matplotlib_backend'
# ]

【六】包

【1】什么是包

  • 模块是功能和集合体,将开发的当前模块的所有功能都放到了一个 模块中

  • 例如:加(逻辑验证) 减(逻辑验证) 乘(逻辑验证) 除(逻辑验证)

  • 将上述四个模块统一成一个文件夹,从这个文件夹中导入指定的功能即可

  • 包就是模块的几何体

【2】如何创建包

# 【1】创建一个文件夹
# 在文件夹内部创建一个__init__.py文件
# 这个文件就叫包# 【2】在pycharm右键文件新建package
# 自动创建__init__.py文件

【3】使用包

(1)方式一
  • __init__.py

# 这个文件是空白
  • add.py

def add(x, y):print("加法功能")if not x.isdigit() or not y.isdigit():return False, f'当前数字格式错误'return True, int(x) + int(y)
  • multy.py

def multy(x, y):print(f"乘法功能")if not x.isdigit() or not y.isdigit():return False, f'当前数字格式错误'return True, int(x) * int(y)
  • main.py

from calculator import add,multy# <module 'calculator.add' from 
print(add.add('1','2'))
(2)方式二
  • __init__.py

# 在这个文件中注册,如果不在这注册就只能和上面一样导入模块名from .add import add
from .multy import multy
  • main.py

from calculator import add,multyx = '2'
y = '9'print(add(x, y))  # 这里的add是方法名
print(multy(x, y))  # 这里的add是方法名

【七】导入语法总结

# import 模块名 语法 只会检索当前模块内的所有变量名
# import 包名 语法 会自动检索 __init__.py文件内的所有变量名,然后再去检索每一个模块的里面的变量名
# 加载的时候多加载一层__init__.py
# 查找的时间也多查找一层__init__.py# 不管是在模块还是包还是自己文件中,只要检索到指定名字就好停止检索

【八】json模块

【1】什么是序列化

  • 将Python中的字典、列表、元组 ... 转换成 字符串类型

  • 如果使用str强制转换数据类型,造成的后果就是转换后的字符串无法转回Python对象

【2】什么是反序列化

  • 将字符串类型的数据转换成Python对象(列表、字典、元组 ... )

  • 能将python对象转为字符串 --> 字符串转回python对象

【3】json模块

(1)导入json模块
import json
(2)保存和读取
[1] 序列化保存Python对象数据
  • json.dump()保存py数据到json文件中

import jsonuser_data_dict = {'username': "knight","password": "123"
}
# 保存到本地文件中,保存进去的是字典格式,文件格式为json数据
with open("user_data.json", "w", encoding="utf-8") as file:json.dump(obj=user_data_dict, fp=file)# {"username": "knight", "password": "123"}# 在内部自动将单引号全部转换为双引号
[2] 将json格式数据转换为Python对象数据
  • json.load()转换为Python数据

with open("user_data.json",'r',encoding="utf-8") as file:data = json.load(file)
print(data,type(data))
#{'username': 'knight', 'password': '123'} <class 'dict'>
(3)转换
# 反序列化和序列化方法转换
# 将一个字典转换为字符串 再转回字典
[1] 将字典转换为字符串格式
data_json_str = json.dumps(obj=user_data_dict)
print(data_json_str, type(data_json_str))
# {"username": "knight", "password": "123"} <class 'str'>
[2] 将字符串转换为字典
data_json_dict = json.loads(data_json_str)
print(data_json_dict, type(data_json_dict))
# {'username': 'knight', 'password': '123'} <class 'dict'>
(4)保存中文数据
user_data = {'name': "爱意", "age": 18}
with open('data.json', 'w', encoding='utf8') as fp:json.dump(obj=user_data, fp=fp, ensure_ascii=False)# 编码和解码
# 编码 encode(编码格式)
# 解码 decode(编码格式)

这篇关于模块与包及json模块学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

Python sys模块的使用及说明

《Pythonsys模块的使用及说明》Pythonsys模块是核心工具,用于解释器交互与运行时控制,涵盖命令行参数处理、路径修改、强制退出、I/O重定向、系统信息获取等功能,适用于脚本开发与调试,需... 目录python sys 模块详解常用功能与代码示例获取命令行参数修改模块搜索路径强制退出程序标准输入

Python pickle模块的使用指南

《Pythonpickle模块的使用指南》Pythonpickle模块用于对象序列化与反序列化,支持dump/load方法及自定义类,需注意安全风险,建议在受控环境中使用,适用于模型持久化、缓存及跨... 目录python pickle 模块详解基本序列化与反序列化直接序列化为字节流自定义对象的序列化安全注

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

python pymodbus模块的具体使用

《pythonpymodbus模块的具体使用》pymodbus是一个Python实现的Modbus协议库,支持TCP和RTU通信模式,支持读写线圈、离散输入、保持寄存器等数据类型,具有一定的参考价值... 目录一、详解1、 基础概念2、核心功能3、安装与设置4、使用示例5、 高级特性6、注意事项二、代码示例

Vue3 如何通过json配置生成查询表单

《Vue3如何通过json配置生成查询表单》本文给大家介绍Vue3如何通过json配置生成查询表单,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录功能实现背景项目代码案例功能实现背景通过vue3实现后台管理项目一定含有表格功能,通常离不开表单

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方