当前位置: 首页 > news >正文

Python笔记之跨文件实例化、跨文件调用、导入库

Python笔记之跨文件实例化、跨文件调用、导入库

在这里插入图片描述

code review!

文章目录

  • Python笔记之跨文件实例化、跨文件调用、导入库
    • 1. 核心对比表格(完整汇总)
      • 1.1 自定义模块跨文件调用汇总表
      • 1.2 第三方库使用汇总表
      • 1.3 导入方式选择决策表
    • 2. 基础示例(快速上手)
      • 2.1 文件结构
      • 2.2 a.py(被导入文件)
      • 2.3 b.py(调用文件)
        • 2.3.1 方式一:选择性导入
        • 2.3.2 方式二:模块导入
    • 3. 第三方库使用示例
      • 3.1 HTTP 请求库
      • 3.2 日志库
    • 4. 常见问题快速解决
      • 4.1 循环导入
      • 4.2 命名冲突
      • 4.3 可选依赖
    • 5. 最佳实践总结
    • 6. 快速参考
      • 6.1 导入语法速查
      • 6.2 适用场景速查

1. 核心对比表格(完整汇总)

1.1 自定义模块跨文件调用汇总表

对象类型定义示例导入方式使用方式完整代码示例适用场景
class Calculator:from module_a import Calculatorcalc = Calculator()calc = Calculator("name")需要创建多个实例
import module_acalc = module_a.Calculator()calc = module_a.Calculator("name")避免命名冲突
函数def calculate(a, b):from module_a import calculateresult = calculate(1, 2)result = calculate(10, 20)频繁调用
import module_aresult = module_a.calculate(1, 2)result = module_a.calculate(10, 20)明确来源
变量x = 10from module_a import xprint(x)print(f"Value: {x}")直接访问
import module_aprint(module_a.x)print(f"Value: {module_a.x}")保持命名空间
预实例化对象calculator = Calculator()from module_a import calculatorcalculator.add(1, 2)result = calculator.add(5, 3)共享全局实例
import module_amodule_a.calculator.add(1, 2)result = module_a.calculator.add(5, 3)明确对象来源
类方法@classmethod def create():from module_a import CalculatorCalculator.create()obj = Calculator.create()工厂方法
静态方法@staticmethod def validate():from module_a import CalculatorCalculator.validate(5)valid = Calculator.validate(5)工具方法
包中的类package/module.py: class Xfrom package.module import Xx = X()x = X("param")包结构项目
包的公开接口__init__.py: from .module import Xfrom package import Xx = X()x = X("param")包的便捷访问

1.2 第三方库使用汇总表

库类型导入方式实例化/使用方式跨文件共享模式代码示例常见用途
HTTP请求库import requestssession = requests.Session()全局sessionglobal_session = requests.Session()API客户端
from requests import Sessionsession = Session()配置化sessionsession = Session(); session.headers.update({})自定义配置
日志库import logginglogger = logging.getLogger(name)命名日志器app_logger = logging.getLogger("app")应用日志
from logging import getLoggerlogger = getLogger(name)快速访问logger = getLogger(__name__)模块日志
数据库库import sqlite3conn = sqlite3.connect(db)连接池conn = sqlite3.connect("app.db")数据存储
配置库import configparserconfig = ConfigParser()全局配置config = ConfigParser(); config.read()配置管理
JSON库import jsonjson.loads() / json.dumps()直接函数调用data = json.loads(json_string)数据序列化
时间库import datetimedatetime.now()工具函数now = datetime.datetime.now()时间处理
数学库import mathmath.sqrt()直接函数调用result = math.sqrt(16)数学计算
from math import sqrtsqrt()直接访问result = sqrt(16)频繁使用

1.3 导入方式选择决策表

场景推荐导入方式原因示例
只使用1-2个对象from module import obj1, obj2简洁直接from math import sqrt, pi
使用多个对象import module避免命名冲突import numpy as np
对象名很长from module import LongClassName as Short提高可读性from requests import Session as S
包的公开接口from package import PublicClass符合设计意图from django.http import HttpResponse
避免命名冲突import module1; import module2保持命名空间import os; import sys
条件导入try: import optional_lib except:可选依赖try: import numpy except: numpy = None

2. 基础示例(快速上手)

2.1 文件结构

a.py
b.py

2.2 a.py(被导入文件)

x = 10def bar():print("bar")class Foo:def hello(self):print("hello")foo = Foo()

2.3 b.py(调用文件)

2.3.1 方式一:选择性导入
from a import Foo, bar, x, foof = Foo()
bar()
print(x)
foo.hello()
2.3.2 方式二:模块导入
import af = a.Foo()
a.bar()
print(a.x)
a.foo.hello()

3. 第三方库使用示例

3.1 HTTP 请求库

# config.py
import requests
session = requests.Session()# main.py
from config import session
response = session.get("https://api.example.com")

3.2 日志库

# logger.py
import logging
logger = logging.getLogger("app")# main.py
from logger import logger
logger.info("Application started")

4. 常见问题快速解决

4.1 循环导入

# 解决方案:函数内导入
def get_processor():from file_b import DataProcessor  # 延迟导入return DataProcessor()

4.2 命名冲突

# 解决方案:使用别名
from module_a import Logger as LoggerA
from module_b import Logger as LoggerB

4.3 可选依赖

# 解决方案:条件导入
try:import pandas as pdHAS_PANDAS = True
except ImportError:HAS_PANDAS = Falsedef process_data(data):if HAS_PANDAS:return pd.DataFrame(data)else:return data  # 降级处理

5. 最佳实践总结

原则说明示例
明确优于简洁清楚表达导入来源import requests 而非 from requests import *
一次性导入在文件顶部集中导入所有import语句放在文件开头
避免深层导入减少包的嵌套层次from myproject.utils import helper
使用__all__控制包的公开接口__all__ = ["PublicClass", "public_function"]
文档化依赖明确说明外部依赖在模块顶部注释说明依赖的库

6. 快速参考

6.1 导入语法速查

import module                    # 导入模块
from module import obj          # 导入对象
from module import obj as alias # 导入并重命名
from package.module import obj  # 包中模块导入
from . import module           # 相对导入(包内)
from ..parent import module    # 上级包导入

6.2 适用场景速查

  • 小脚本from module import needed_items
  • 大项目import module + 包结构
  • 库开发:使用 __init__.py 控制公开接口
  • 可选功能:条件导入 + 异常处理
http://www.xdnf.cn/news/1172701.html

相关文章:

  • 基于 XGBoost 与 SHAP 的医疗自动化办公与可视化系统(下)
  • 用Phi-3 Mini微调实现英文到尤达语翻译
  • SpringCloud sentinel服务熔断 服务降级
  • 希尔排序cc
  • 电子电气架构 --- 汽车软件全生命周期
  • Cesium绘制圆锥
  • 「源力觉醒 创作者计划」深度讲解大模型之在百花齐放的大模型时代看百度文心大模型4.5的能力与未来
  • 深度图像滤波
  • Java 时间处理 API 全解析:从 JDK7 到 JDK8 的演进
  • Linux基本命令
  • Python实战:基于Streamlit的股票筛选系统,实时K线图+数据缓存优化
  • 应急响应基础
  • 通用图片 OCR 到 Word API 数据接口
  • 增强LLM最后隐藏层的意义与效果
  • 代码随想录算法训练营第五十二天|图论part3
  • 分享鸢尾花数据集:iris.csv,以及简单数据分析与分类预测示例(决策树)
  • 动态IP+AI反侦测:新一代爬虫如何绕过生物行为验证?
  • PyTorch中nn.Module详解和综合代码示例
  • 【前端】ikun-pptx编辑器前瞻问题三: pptx的图片如何提取,并在前端渲染。
  • 7月23日华为机考真题第二题-200分
  • python在windows电脑找回WiFi密码
  • 前端/后端,前台/中台/后台概念区别
  • python自动化测试框架,封装方法方式
  • 【Unity编辑器开发与拓展Handles】
  • CRMEB 单商户PRO多商户通用去版权教程
  • Oracle迁移到高斯,查询字段默认小写,解决办法
  • 微软Fabric重塑数据管理:Forrester报告揭示高ROI
  • 基于Kafka实现简单的延时队列
  • BUUCTF(web)部分题解
  • 设计模式九:构建器模式 (Builder Pattern)