我有两个模块:moduleParent和moduleChild标杆python脚本揭示神秘的时间延迟
我做的moduleParent是这样的:
import moduleChild
#a bunch of code
start = time.time()
moduleChild.childFunction()
finish = time.time()
print "calling child function takes:", finish-start, "total seconds"
#a bunch of code
我做这样的事情在moduleChild:
def childFunction():
start = time.time()
#a bunch of code
finish = time.time()
print "child function says it takes:", finish-start, "total seconds"
输出看起来是这样的:
calling child function takes: .24 total seconds
child function says it takes: 0.0 total seconds
所以我的问题是,这些.24多余的秒来自哪里?
感谢您的专业知识。
#这里是“childFuntion”的实际代码。它真的不应该需要.24秒。
def getResources(show, resourceName='', resourceType=''):
'''
get a list of resources with the given name
@show: show name
@resourceName: name of resource
@resourceType: type of resource
@return: list of resource dictionaries
'''
t1 = time.time()
cmd = r'C:\tester.exe -cmdFile "C:\%s\info.txt" -user root -pwd root'%show
cmd += " -cmd findResources -machineFormatted "
if resourceName:
cmd += '-name %s'%resourceName
if resourceType:
cmd += '_' + resourceType.replace(".", "_") + "_"
proc=subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
output = proc.stdout.read()
output = output.strip()
resourceData = output.split("\r\n")
resourceData = resourceData[1:]
resourceList = []
for data in resourceData:
resourceId, resourceName, resourceType = data.split("|")
rTyp = "_" + resourceType.replace(".", "_") + "_"
shot, assetName = resourceName.split(rTyp)
resourceName = assetName
path = '//projects/%s/scenes/%s/%s/%s'%(show, shot, resourceType.replace(".", "/"), assetName)
resourceDict = {'id':resourceId, 'name':resourceName, 'type':resourceType, 'path':path }
resourceList.append(resourceDict)
t2 = time.time()
print (" ", t2 - t2, "seconds")
return resourceList
这是确切的输出?这些线不正确吗? –
它不是确切的输出,不。这只是一个简单的例子。 –
你有你的答案't2 - t2' = 0 – Lynch