一、概念介绍

在介绍目录directory与包package的区别之前,先理解一个概念---模块

模块的定义:本质就是以.py结尾的python文件,模块的目的是为了其他程序进行引用。

目录(Dictionary):

Dictionary在pycharm中就是一个文件夹,放置资源文件,对应于在进行JavaWeb开发时用于放置css/js文件的目录,或者说在进行物体识别时,用来存储背景图像的文件夹。该文件夹其中并不包含_ _ init.py_ _文件

包(Package):

对于Python package 文件夹而言,与Dictionary不同之处在于其会自动创建__init__.py文件。 
简单的说,python package就是一个目录,其中包括一组模块和一个__init__.py文件。

二、导入模块

导入模块的方法:

import module_name
import module1_name,module2_name
from module_name import * ---> 一般import * 不建议使用
from module_name import m1,m2,m3 ---> m1为module_name下面的方法或变量
from module_name import logger as logger_a ---> 为导入的变量或方法取个别名,引用时直接用别名

1.同级目录下模块的导入:

在main_day41.py中导入para_day41.py,两种方法:

#方法一: 相当于把para_day41.py中的所有代码拷贝过来赋值给变量para_day41,引用时直接用"该变量."
import para_day41
para_day41.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day4/main_day41.py
in the para_day41
#方法二: 只把para_day41.py中name变量和show_para方法拷贝过来,可以直接用(推荐用该方法)
from para_day41 import name,show_para
print(name)
show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day4/main_day41.py
para_day41
in the para_day41

2.不同级目录下模块的导入:

(1)导入子目录下的模块

main.py中导入day51目录下面para_day51.py

import day51.para_day51
day51.para_day51.show_para()
from day51.para_day51 import *
show_para()
from day51 import para_day51
para_day51.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day5/main.py
in the para_day51

(2)导入上级目录下的模块

day22目录下面的main_day22.py导入day21目录下的para_day21.py

注:执行main_day22.py时,要导入day21目录下的para_day21.py,具体的搜索路径是这样的:

  首先,python需要在当前目录下去找para_day21.py,发现没有,然后就到sys.path列表中的每个路径下面去找:

['D:\\Pyexample\\20190220Day2\\day22', 'D:\\Pyexample', 'D:\\Pyexample\\W3', 'D:\\Pyexample\\20181113', 'D:\\Pyexample\\CSP\\cspmonitor', 'D:\\Pyexample\\python', 'D:\\python365\\python36.zip', 'D:\\python365\\DLLs', 'D:\\python365\\lib', 'D:\\python365', 'D:\\python365\\lib\\site-packages']

  结果仍没找到,所以就会报错:

Traceback (most recent call last):
File "D:/Pyexample/20190220Day2/day22/main_day22.py", line 21, in <module>
import day21.para_day21
ModuleNotFoundError: No module named 'day21'

  解决办法:需要手动将para_day21.py所在的父目录或上上级目录加到sys.path列表中,让python可以搜索到即可

import sys,os
print(sys.path) p = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) #获取要导入模块的上上级目录
print(p) sys.path.insert(0,p) #把获取到的上上级目录加到sys.path列表中 from day21 import para_day21
print(para_day21.name)
para_day21.show_para() 运行结果:
['D:\\Pyexample\\20190220Day2\\day22', 'D:\\Pyexample', 'D:\\Pyexample\\W3', 'D:\\Pyexample\\20181113', 'D:\\Pyexample\\CSP\\cspmonitor', 'D:\\Pyexample\\python', 'D:\\python365\\python36.zip', 'D:\\python365\\DLLs', 'D:\\python365\\lib', 'D:\\python365', 'D:\\python365\\lib\\site-packages']
D:\Pyexample\20190220Day2
['D:\\Pyexample\\20190220Day2', 'D:\\Pyexample\\20190220Day2\\day22', 'D:\\Pyexample', 'D:\\Pyexample\\W3', 'D:\\Pyexample\\20181113', 'D:\\Pyexample\\CSP\\cspmonitor', 'D:\\Pyexample\\python', 'D:\\python365\\python36.zip', 'D:\\python365\\DLLs', 'D:\\python365\\lib', 'D:\\python365', 'D:\\python365\\lib\\site-packages']
para_day21
in the para_day21

或者把要导入模块的父目录加到sys.path列表中

p = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) + '\\day21'  #获取要导入模块的父目录
sys.path.insert(0,p)
import para_day21
print(para_day21.name)
para_day21.show_para()

三、导入包

导入包的本质就是执行这个包下面的__init__.py文件

1.同级路径下包的导入:

main.py中导入包day31,直接用import 包名即可

import day31

(1)__init__.py中没有内容时

D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py

Process finished with exit code 0

(2)__init__.py中有内容时:

D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__ Process finished with exit code 0

2.不同级路径下包的导入:

前提:需要将要导入的包所在的路径添加到sys.path列表中,方法同上,不再赘述。

3. 导入包中的模块

只是导入一个包并没有什么实际意义,包是用来从逻辑上组织模块的,所以实际项目中更多的是导入包中的模块,导入包中模块的方法:

from Package1 import Module1
from Package1 import Package2
from Package1.Module1 import m1,m2 ---> m1,m2为模块中的变量或方法
from Package1.Module1 import *
import Package1.Module1
import Package1.Package2

要导入的包及其模块结构如下:

(1)在main.py中导入包day31下面的para_day31.py或者para_day32.py模块

import day31.para_day31,day31.para_day32
day31.para_day31.show_para()
day31.para_day32.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__
in the para_day31
in the para_day32 Process finished with exit code 0

或者:

from day31 import para_day31,para_day32
para_day31.show_para()
para_day32.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__
in the para_day31
in the para_day32 Process finished with exit code 0

或者:

from day31.para_day31 import show_para,name
print(name)
show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__
para_day31
in the para_day31 Process finished with exit code 0

或者:

from day31.para_day31 import *
print(name)
show_para()

(2)在main.py中导入包day31下面所有的模块,即全部导入

from day31 import *
para_day31.show_para()
para_day32.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__
Traceback (most recent call last):
File "D:/Pyexample/20190220Day3/main.py", line 35, in <module>
para_day31.show_para()
NameError: name 'para_day31' is not defined Process finished with exit code 1

此时,需要用到__init__.py文件中的__all__变量,在day31包中的__init__.py文件中定义如下:

"""
@Author:janson
@Date:2019/2/20
@File:__init__
""" print("in the day31 __init__") __all__ = ['para_day31','para_day32']

这时 from day31 import * 就会把注册在包__init__.py 文件中 __all__ 列表中的子模块和子包导入到当前作用域中来:

再次运行就不会报错了:

from day31 import *
para_day31.show_para()
para_day32.show_para() 运行结果:
D:\python365\python3.exe D:/Pyexample/20190220Day3/main.py
in the day31 __init__
in the para_day31
in the para_day32 Process finished with exit code 0

python入门-PyCharm中目录directory与包package的区别及相关import详解的更多相关文章

  1. PyCharm中目录directory与包package的区别及相关import详解

    一.概念介绍 在介绍目录directory与包package的区别之前,先理解一个概念---模块 模块的定义:本质就是以.py结尾的python文件,模块的目的是为了其他程序进行引用. 目录(Dire ...

  2. Python入门之PyCharm中目录directory与包package的区别

    对于Python而言,有一点是要认识明确的,python作为一个相对而言轻量级的,易用的脚本语言(当然其功能并不仅限于此,在此只是讨论该特点),随着程序的增长,可能想要把它分成几个文件,以便逻辑更加清 ...

  3. Python入门之面向对象module,library,package之间区别

    背景 Python中有一些基本的名词,很多人,尤其是一些初学者,可能听着就很晕. 此处,简单总结一下,module,library,package之间的大概区别. Python中的module的简介 ...

  4. Opencv中Mat矩阵相乘——点乘、dot、mul运算详解

    Opencv中Mat矩阵相乘——点乘.dot.mul运算详解 2016年09月02日 00:00:36 -牧野- 阅读数:59593 标签: Opencv矩阵相乘点乘dotmul 更多 个人分类: O ...

  5. JAVA高级架构师基础功:Spring中AOP的两种代理方式:动态代理和CGLIB详解

    在spring框架中使用了两种代理方式: 1.JDK自带的动态代理. 2.Spring框架自己提供的CGLIB的方式. 这两种也是Spring框架核心AOP的基础. 在详细讲解上述提到的动态代理和CG ...

  6. 【翻译】Anatomy of a Program in Memory—剖析内存中的一个程序(进程的虚拟存储器映像布局详解)

    [翻译]Anatomy of a Program in Memory—剖析内存中的一个程序(进程的虚拟存储器映像布局详解) . . .

  7. 图论中DFS与BFS的区别、用法、详解…

    DFS与BFS的区别.用法.详解? 写在最前的三点: 1.所谓图的遍历就是按照某种次序访问图的每一顶点一次仅且一次. 2.实现bfs和dfs都需要解决的一个问题就是如何存储图.一般有两种方法:邻接矩阵 ...

  8. 图论中DFS与BFS的区别、用法、详解?

    DFS与BFS的区别.用法.详解? 写在最前的三点: 1.所谓图的遍历就是按照某种次序访问图的每一顶点一次仅且一次. 2.实现bfs和dfs都需要解决的一个问题就是如何存储图.一般有两种方法:邻接矩阵 ...

  9. MySQL中tinytext、text、mediumtext和longtext等各个类型详解

    转: MySQL中tinytext.text.mediumtext和longtext等各个类型详解 2018年06月13日 08:55:24 youcijibi 阅读数 26900更多 个人分类: 每 ...

随机推荐

  1. POJ3264【线段树】

    求区间最值-(基础,继续) code---.. #include<cstdio> #include<iostream> #include<string.h> #in ...

  2. 用动态链表high-poj 1528

    //2333333 题目超级水,但是!刚学了链表拿来high一high也不错啊. #include <iostream> #include <stdio.h> #include ...

  3. spring AOP excution表达式各符号意思

    execution(*com.sample.service.impl..*.*(..)) 符号 含义 execution() 表达式的主题 第一个“*”符号 表示返回值的类型任意: com.sampl ...

  4. vim 不同的插入方式

    在命令行模式下进入到输入模式 可以敲击 i.a.o. s. I. A. O. S 它们之间的区别做下备忘:i:在光标所在字符前开始插入a:在光标所在字符后开始插入o:在光标所在行的下面另起一新行插入s ...

  5. fiddler安装及抓取http和https请求

    安装fiddler 安装完成,此时就可以抓取http请求了 如果要抓取https请求,就需要更新fiddler为最新版,并安装证书 1.检查更新fiddler为最新版 2.下载证书并安装 https证 ...

  6. 统计Apache或nginx日志里访问次数最多的前十个IP

    1.根据访问IP统计UV awk '{print $1}' access.log|sort | uniq -c |wc -l 2.统计访问URL统计PV awk '{print $7}' access ...

  7. 最短路之Floyd(弗洛伊德)

    只有五行的Floyd最短路算法: 核心代码 每次都更新通过k点,然后从i到j的最短路程...

  8. python之请求报文对比(假定最多二维字典)

    两段请求报文,判断不一样的key和value,只判断d2里和d1不同的值,和全部不同的key ok_req={ "version": "9.0.0", &quo ...

  9. 138 Copy List with Random Pointer 复制带随机指针的链表

    给出一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点.返回一个深拷贝的链表. 详见:https://leetcode.com/problems/copy-list- ...

  10. Spark网络通信分析

    之前分析过spark RPC的基本流程(spark RPC详解),其实无论是RPC还是Spark内部的数据(Block)传输,都依赖更底层的网络通信,本文将对spark的网络通信做一下剖析. 1,概要 ...