python 一个.py文件如何调用另一个.py文件中的类和函数【转载】

转载 https://blog.csdn.net/winycg/article/details/78512300

https://www.linuxidc.com/Linux/2019-05/158423.htm

在同一个文件夹下,调用函数
A.py文件:

def add(x,y):
    print('和为:%d'%(x+y))

B.py文件:

import A
A.add(1,2)

或 

from A import add
add(1,2)

调用类:
A.py文件:

class A:
    def __init__(self,xx,yy):
        self.x=xx
        self.y=yy
    def add(self):
        print("x和y的和为:%d"%(self.x+self.y))


B.py文件:

from A import A
a=A(2,3)
a.add()

import A
a=A.A(2,3)
a.add()

在不同文件夹下
A.py文件的文件路径:E:\PythonProject\winycg

B.py文件:

import sys
sys.path.append(r'E:\PythonProject\winycg')
'''python import模块时, 是在sys.path里按顺序查找的。
sys.path是一个列表,里面以字符串的形式存储了许多路径。
使用A.py文件中的函数需要先将他的文件路径放到sys.path中'''
import A
 
a=A.A(2,3)
a.add()

Python中模块互相调用的例子

Python中模块互相调用容易出错,经常是在本地路径下工作正常,切换到其他路径来调用,就各种模块找不到了。解决方法是通过__file__定位当前文件的真实路径,再通过sys.path.append()来获取相对路径更新$PATH即可。

假设代码结构如下:

- mod_a
    __init__.py     # 模块文件夹内必须有此文件
    aaa.py
- mod_b
    __init__.py     # 模块文件夹内必须有此文件
    bbb.py
- ccc.py
  • 调用同级模块

如果aaa.py要调用bbb.py的内容,可以在aaa.py中如下写:

import sys
sys.path.append(osp.join(osp.dirname(__file__), '..'))  # 扫除路径迷思的关键!
from mod_b.bbb import *
  • 调用下级模块

如果ccc.py要调用bbb.py的内容,可以在ccc.py中如下写:

from mod_b.bbb import *
  • 调用上级模块

如果aaa.py要调用ccc.py的内容,可以在aaa.py中如下写:

import sys
sys.path.append(osp.join(osp.dirname(__file__), '..'))
from ccc import *

代码示例:

aaa.py如下:

# -*- coding: utf-8 -*-

from __future__ import print_function
import os.path as osp
import sys
sys.path.append(osp.join(osp.dirname(__file__), '..'))
from mod_b.bbb import *
from ccc import *

def print_a():
  print('this is a')
  
def _call_mod_b():
  print_a()
  print_b()
  
def _call_mod_c():
  print_c()


if __name__=='__main__':
  _call_mod_b()
  _call_mod_c()

bbb.py如下:

# -*- coding: utf-8 -*-

from __future__ import print_function

def print_b():
  print('this is b')


if __name__=='__main__':
  pass

ccc.py如下:

# -*- coding: utf-8 -*-

from __future__ import print_function
from mod_b.bbb import *

def print_c():
  print('this is c')
  
def _call_mod_b():
  print_c()
  print_b()
  

if __name__=='__main__':
  _call_mod_b()

如此,当不管在何处调用aaa.py时,结果都一样,如下:

this is a
this is b
this is c

如果调用ccc.py,结果如下:

this is c
this is b

 

 

 

  • 20
    点赞
  • 131
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值