从模块到python文件的两种用法

01模块的四种形式

模块

就是从逻辑上组织python代码(变量,函数,类,逻辑:实现一个功能),本质就是.py结尾的python文件(文件名是test.py的话,它的对应模块名就是test)

用来从逻辑上组件模块,本质就是一个目录(必须带有一个__init__.py文件)

导入模块

本质就是把python文件解释一遍

导入包

本质就是执行该报下的__init__.py文件;如果要导入包下面的模块:需要先导入包,然后从包下的__init__.py文件中再导入该包下的模块

python可以看成是手机??--》pip看成应用管家--》模块就是应用软件

1.系统自带软件--》不需要安装

2.需要下载的软件

3.自定义软件

1.python内置模块:python解释器启动自带的time/random/os/sys
2.pip安装的模块,pip install jieba
3.自定义模块--》自定义代码
4.包(模块)-》未来详细讲

2.import与from..import..

import

以time为例:
import time

1.开辟内存空间,内存空间命名为time
2.把time.py中所有代码读入空间,然后运行
3.通过time.方法名使用time模块中的方法

#test.py

import time

import time as t  #变量名t指向time模块的名称空间

from time import sleep
from time import sleep,localtime

优点:永不冲突
缺点:每次导入多输入几个字符,非常麻烦

from...import...

以time里的sleep为例

from time import sleep

1.开辟内存空间,内存空间命名为time
2.把time.py中所有代码读入空间,然后运行
3.把sleep()方法读入import和from import,因此可以直接使用方法名

# *__all__=['']
#test.py

__all__ = ['f1','f2']

def f1():
    print(1)
def f2():
    print(2)
def f3():
    print(3)

from test import *
    test.f3()    #无法运行

import test
    test.f3()   # 3

优点:少打几个字符
缺点:容易冲突

3.循环导入

#m1.py
from m2 import y
x = 10
print('m1:',x,y)

#m2.py
from m1 import x
y = 20
print('m2:',x,y)

过程:m1.py --> m2.py --> m1.py ...

结果:x/y在这个过程中一直没有生成

解决方案一

#m1.py
x = 10
from m2 import y
print('m1:',x,y)

#m2.py
y = 20
from m1 import x
print('m2:',x,y)

过程:m1.py -->10 20 --> m2.py -->10 20--> m1.py --> x = 10 20

结果:m2: 10 20
m1: 10 20
m2: 10 20

解决方案二

#m1.py
def f1():
    from m2 import y
    print(y)
x = 10

#m2.py
def f1():
    from m1 import x
y = 20 

过程:f1() --> m2.py --> y = 20

结果:y = 20

4.模块的搜索路径

  1. 先从内存中寻找

    from m2 import y
    print(y)
    import time
    time.sleep(10)  # 10s内删除了m2
    
    from m2 import y
    print(y)
  2. 再从内置中寻找
    from time import time
    print(time)
  3. 然后从自定制寻找
    x = 10
  4. 最后从环境变量中寻找
    import sys
    print(sys.path)  # 环境变量,模块就是在某个路径中,需要添加路径,在这里找
    sys.path.append(r'D:\badboy\第十二期正式开课\day15')
    
    # del sys.path[1]
    print(sys.path)
    
    import testt
    testt.f1()

(这段干货是我从别人博客那边偷的)

5.Python文件的两种用途

作为模块文件,模块可以有多个

作为执行文件,执行文件只有一个

# m1.py
x = 10
if __name__ == '__main__':
print(x)
# m2.py
import m1

if __name__ == ‘__main__‘:这段代码在pycharm里面只需要打一个main然后tab即可打出来,不需要一个字一个字打

当运行m1时__name__ == ‘__main__‘所以会输出x

运行m2时__name__ != ‘__main__‘(if条件不成立)会报错

原文地址:https://www.cnblogs.com/jimGraymane/p/11593062.html

时间: 2024-10-11 00:20:40

从模块到python文件的两种用法的相关文章

Python文件的两种用途

目录 Python文件的两种用途(掌握) Python文件的两种用途(掌握) python文件总共有两种用途,一种是执行文件:另一种是被当做模块导入. 编写好的一个python文件可以有两种用途: 脚本,一个文件就是整个程序,用来被执行 模块,文件中存放着一堆功能,用来被导入使用 # aaa.py x = 1 def f1(): print('from f1') def f2(): print('from f2') f1() f2() # run.py import aaa 如果直接运行run.

1.模块2.循环导入问题及解决思路3.区分py文件的两种类型4.模块的查找顺序5.模块的绝对导入与相对导入6.项目开发的目录规范

一.模块 什么是模块? 模块就是一系列功能的结合体 模块的三种来源: 1.内置的(python解释器自带的) 2.第三方的(别人写的) 3.自定义的(你自己写的) 模块的四种表现形式: 1.使用python编写的py文件(也就是意味着py文件也是可以称之为模块 2.已被编译为共享库或DLL的或C++扩展(了解) 3.把一系列模块组织到一起的文件夹(文件夹下有一个__init__.py文件,该文件夹称之为包) 4.使用C编写并连接到Python解释器的内置模块 模块选择 1.用别人写好的模块(内置

Python文件遍历二种方法

分享下有关Python文件遍历的两种方法,使用的OS模块的os.walk和os.listdir实现. 关于Python的文件遍历,大概有两种方法,一种是较为便利的os.walk(),还有一种是利用os.listdir()递归遍历.方法一:利用os.walkos.walk可以自顶向下或者自底向上遍历整个文件树,然后返回一个含有3个元素的tuple,(dirpath, dirnames, filenames).注意,os.walk()会返回一个generater,所以调用的时候一定要放到for循环中

解析XML文件的两种方式 SAX和DOM

1.数据解析 解析的基本概念 所谓“解析”:从事先规定好的格式中提取数据 解析的前提:提前约定好格式,数据提供方按照格式提供数据.数据获取方则按照格式获取数据 iOS开发常见的解析:XML解析.JSON解析 2.XML数据结构 XML:Extensible Markup language(可扩展标记语言),主流数据格式之一,可以用来存储和传输数据. XML数据格式的功能 数据交换 内容管理 用作配置文件 XML数据结构的语法 声明 节点使用一对标签表示:起始和结束标签. 根节点是起始节点,只有一

UI进阶 解析XML文件的两种方式 SAX和DOM

1.数据解析 解析的基本概念 所谓“解析”:从事先规定好的格式中提取数据 解析的前提:提前约定好格式,数据提供方按照格式提供数据.数据获取方则按照格式获取数据 iOS开发常见的解析:XML解析.JSON解析 2.XML数据结构 XML:Extensible Markup language(可扩展标记语言),主流数据格式之一,可以用来存储和传输数据. XML数据格式的功能 数据交换 内容管理 用作配置文件 XML数据结构的语法 声明 节点使用一对标签表示:起始和结束标签. 根节点是起始节点,只有一

MySQL命令执行sql文件的两种方法

MySQL命令执行sql文件的两种方法 摘要:和其他数据库一样,MySQL也提供了命令执行sql脚本文件,方便地进行数据库.表以及数据等各种操作.下面笔者讲解MySQL执行sql文件命令的两种方法,希望能给刚开始学习 MySQL 数据库的朋友们. 学习过 SQLServer 或 Oracle 的朋友会知道,sql 脚本是包含一到多个 sql 命令的 sql 语句集合,我们可以将这些 sql 脚本放在一个文本文件中(我们称之为“sql 脚本文件”),然后通过相关的命令执行这个 sql 脚本文件.基

day2-操作系统,编程语言分类,执行Python程序的两种方式,变量,python的内存管理,

1    什么是操作系统 操作系统位于计算机与应用软件之间,是一个协调,管理,控制计算机硬件资源与软件资源的控制程序 2     为何要有操作系统? 1,控制硬件. 2,把对硬件的复杂的操作封装成优美简单的接口,给用户或者应用程序去使用 注意:一套完整的计算机系统包含三部分 应用程序:比如QQ,暴风影音 操作系统:比如windows linux unix 计算机硬件 强调:我们以后开发的都是应用程序,应用程序无法直接操作硬件,但凡要操作硬件,都是调用操作系统的接口 3 编程语言的分类 1,机器语

操作系统+编程语言的分类+执行python程序的两种方式+变量

1.什么是操作系统? 操作系统就是一个协调\管理\控制计算机硬件资源与软件资源的一个控制程序. 2.为何要操作系统? a.把复杂的硬件操作封装成简单的功能\接口用来给用户或者程序来使用(文件) b.把应用程序对硬件的竞争变得有序 3.如何用操作系统? 一套完整的计算机系统分为3层: 应用程序层 操作系统层 计算机硬件层 编程语言的分类 1.机器语言:直接使用二进制指令去编高于写程序(直接操作硬件) 优点:计算机无障碍理解,运行效率高. 缺点:开发效率低 2.汇编语言:使用英文标签代替二进制指令去

pdf文件怎么修改 修改PDF文件的两种方法

都说PDF格式的文件不能修改,我就呵呵了!不管你们信不信,反正我是不信.因为我会修改PDF文件,并且方法还不止一种.想知道我是怎么修改PDF文件的吗?下面我就告诉大家修改PDF文件的两种方法. 方法一 1.方法一就是将PDF文件转换成一种可容易编辑的文档,如:word.excel.ppt等格式,然后再进行编辑,编辑好后再将其转换成PDF格式,是不是很简单!具体是该如何转换的,下面有详细教程. 2.下载一个PDF转换器,并将它安装在电脑上.工具最好是支持双向转换的那种,如:http://www.x