文章目录
在很多时候,为了保持代码与代码文件的简洁和逻辑清晰,通常会将许多相类似的函数放在一个文件中,在一个
main.py中去调用它们。调用 Python 函数的时候,大致会存在如下几种情况。
假如现在有这样一个文件树(从其他地方copy的,稍加整改)
A
|-------- __init__.py
|-------- a.py
|-------- main.py
|-------- B
|-------- __init__.py
|-------- b.py
|-------- C
|-------- __init__.py
|-------- c.py
文件内容如下:
# a.py
def a_hello():
print("A_HELLO")
----------------------------
# b.py
def b_hello():
print("B_HELLO")
----------------------------
# c.py
def c_hello():
print("C_HELLO")
----------------------------
# main.py
def main_hello():
print("MAIN_HELLO")
为什么要有
__init__.py文件呢?
【答】在Python工程里,当python检测到一个目录下存在__init__.py文件时,python就会把它当成一个模块(module)。Module跟C++的命名空间和Java的Package的概念很像,都是为了科学地组织化工程,管理命名空间。
__init__.py可以是一个空文件,也可以有非常丰富的内容。
这个比较简单,比如我想在main.py中调用main_hello()函数,那么我直接main_hello()即可
比如我想在main.py中调用a.py中的a_hello()函数,可做如下操作
import a
a.a_hello()
比如我想在main.py中调用文件夹B下b.py中的b_hello()函数,可做如下操作:
from B import b
b.b_hello()
比如我想在c.py中调用a.py中的函数,这时候如果用上面的方法就会报错No module named xx。解决方法就是将目录A加到系统路径下
import sys
sys.path.append('E:\\testnow\\A') #括号内容为文件的绝对路径
注意,sys.path添加目录时注意是在windows还是在linux下,windows下需要用\\,linux下需要用/否则会出错。这样需要区分操作系统,而且需要知道绝对路径,岂不是很不好用。看到有大佬用到过如下操作:
import os
import sys
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))
上面这句话很长,但也不难理解,os.path.dirname(__file__)获取当前文件的绝对路径,os.path.join(xx,'..')在后面追加..,相当于进入上一级目录,然后再os.path.abspath(xx)获取绝对路径,最后sys.path.append()将其加入系统路径当中。经过这些操作之后,被加入系统路径中的所有文件中的函数都可以被调用了。
后面有朋友问了,所以这里再补充一下 2022-09-23
因为原来的项目被我删了,这里我并没有做测试啊,一般我都是这么用的,应该无问题。
比如我想在c.py中调用b.py中的函数,那么c.py的import为
import os
import sys
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))
import B.b as b
b.b_hello()
import os
os.system(r'python tmp.py')
# 最好给文件的绝对路径,否则有可能会找不到文件。
Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和 Python 语句。__init__.py 文件, 该文件的内容可以为空。__init__.py 用于标识当前文件夹是一个包。__init__.py 文件的文件夹。另外,对于导入模块可以使用import model1或from model1 import func1, func2, ...。其实,这两种方式看似一样,但是是有所区别的,具体请看
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我在使用omniauth/openid时遇到了一些麻烦。在尝试进行身份验证时,我在日志中发现了这一点:OpenID::FetchingError:Errorfetchinghttps://www.google.com/accounts/o8/.well-known/host-meta?hd=profiles.google.com%2Fmy_username:undefinedmethod`io'fornil:NilClass重要的是undefinedmethodio'fornil:NilClass来自openid/fetchers.rb,在下面的代码片段中:moduleNetclass
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何