写了一个hiero检查任务渲染结果的脚本
基本思路是写了一个时间判断函数(postSequence_check)来对比transcode任务提交时间和目标文件夹内文件的修改时间来确定渲染是否成功执行,然后通过Hiero提供的postSequence钩子函数将时间判断函数(postSequence_check)注入进Hiero。
import sys
import os,datetime
import time
#GLOBAL_NAMELIST=[]
def updateItem_new (self, originalItem, localtime):
#print sys._getframe().f_code.co_name
global GLOBAL_LOCALTIME,GLOBAL_CLASS_TYPE
GLOBAL_LOCALTIME = time.mktime(localtime)
GLOBAL_CLASS_TYPE = self
"""updateItem - This is called by the processor prior to taskStart, crucially on the main thread.\n
This gives the task an opportunity to modify the original item on the main thread, rather than the clone."""
#if isinstance(self._item, (Sequence,TrackItem)):
#if isinstance(self._item, Clip):
timestamp = self.timeStampString(localtime)
tag = hiero.core.Tag("Transcode " + timestamp, "icons:Nuke.png")
tag.metadata().setValue("tag.path", self.resolvedExportPath())
tag.metadata().setValue("tag.localtime", str(localtime))
# Right now dont add the time to the metadata
# We would rather store the integer time than the stringified time stamp
#tag.setValue("time", timestamp)
# No point in adding script path if we're not planning on keeping the script
if self._preset.properties()["keepNukeScript"]:
tag.metadata().setValue("tag.script", self._scriptfile)
start, end = self.outputRange()
tag.metadata().setValue("tag.startframe", str(start))
tag.metadata().setValue("tag.duration", str(end-start+1))
frameoffset = self._startFrame if self._startFrame else 0
if hiero.core.isVideoFileExtension(os.path.splitext(self.resolvedExportPath())[1].lower()):
frameoffset = 0
tag.metadata().setValue("tag.frameoffset", str(frameoffset))
if self._cutHandles:
tag.metadata().setValue("tag.handles", str(self._cutHandles))
self._tag_guid = tag.guid()
originalItem.addTag(tag)
# The guid of the tag attached to the trackItem is different from the tag instace we created
# Get the last tag in the list and store its guid
self._tag_guid = originalItem.tags()[-1].guid()
hiero.exporters.FnTranscodeExporter.TranscodeExporter.updateItem = updateItem_new
######################################################################################################
######################################################################################################
######################################################################################################
def postSequence_check(self):
#print sys._getframe().f_code.co_name
#print self.__class__
#print self._filebase
if isinstance(self,hiero.exporters.FnTranscodeExporter.TranscodeExporter):
#print "yeah!"
#print self._root
#print self._shotPath
#print self._filebase
#print self._version
#print self._track
#print self.outputRange()
#print self.properties()
#print initDictionary
#GLOBAL_NAMELIST.append(self._filebase)
base_dir = self._root
base_dir = "/".join(base_dir.split('/')[0:-1])
print self._filebase
list = []
timestamplist = []
list = os.listdir(base_dir)
if len(list) > 0:
for i in range(0, len(list)):
path = os.path.join(base_dir,list[i])
if os.path.isfile(path):
path = os.path.join(base_dir, list[i])
if os.path.isdir(path):
continue
timestamp = os.path.getmtime(path)
timestamplist.append(timestamp)
#print GLOBAL_LOCALTIME,min(timestamplist)
if GLOBAL_LOCALTIME > min(timestamplist):
print "(VHQ) This transcode task has some problem:" + self._filebase
else:
print '(VHQ) This transcode task is OK!'
else:
print "(VHQ) This transcode task has some problem:" + self._filebase
else:
base_dir = self._filebase
#base_dir = "/".join(base_dir.split('/')[0:-1])
print base_dir
print str(self.__class__).strip('<').strip('>').strip("'").split('.')[-1] + ' is not transcode render task!'
hiero.core.FnExporterBase.TaskBase.postSequence = postSequence_check
写了一个hiero检查任务渲染结果的脚本的更多相关文章
- 初步学习nodejs,业余用node写个一个自动创建目录和文件的小脚本,希望对需要的人有所帮助
初步学习nodejs,业余用node写个一个自动创建目录和文件的小脚本,希望对需要的人有所帮助,如果有bug或者更好的优化方案,也请批评与指正,谢谢,代码如下: var fs = require('f ...
- 写了一个hiero中添加自定义Token的脚本
Hiero自带Token往往不够用,shotname中自带版本号的情况下要升级版本会很麻烦,比如Shot_0001_v001这样一个序列名,要升级为Shot_0001_v002就必须把_v001之前的 ...
- 随手写的一个检测php连接mysql的小脚本
最近偶然接触到一点点的php开发,要用到mysql数据库,由于mysql和php版本的关系,php5里面连接函数有mysql_connect(),mysqli_connect()两种,php7中又使用 ...
- python 拼写检查代码(怎样写一个拼写检查器)
原文:http://norvig.com/spell-correct.html 翻译:http://blog.youxu.info/spell-correct.html 怎样写一个拼写检查器 Pete ...
- 如何写一个拼写检查器-by Peter Norvig
本文原著:Peter Norvig 中文翻译:徐宥 上个星期, 我的两个朋友 Dean 和 Bill 分别告诉我说他们对 Google 的快速高质量的拼写检查工具感到惊奇. 比如说在搜索的时候键入 ...
- 闲来无事,用Java的软引用写了一个山寨的缓存
闲来无事,用Java的软引用写了一个山寨的缓存 博客分类: java基础 众所周知java中的引用分为 StrongReference.SoftReference.WeakReference.Phan ...
- Pluto - iOS 上一个高性能的排版渲染引擎
WeTest 导读 Pluto 是 iOS 上的一个排版渲染引擎,通过 JSON/JS 文件可以很方便地描述界面元素,开发效率很高,并且在流畅度,内存等方便有保证.pluto.oa.com 上有更多详 ...
- 自己写的一个Vue
下面这里是我自己写的一个小型的vue,原理就是proxy: //Proxy天生没有prototype,因此要加上,不然extends会报错 Proxy.prototype = Proxy.protot ...
- 自己写的一个Solr搜索实例,增删改查+高亮+分页
今天个人coding的模块测试,所以闲暇之余继续研究solr,然后顺带写了一个实例,随便搞的,solr真心不熟,期待认识热爱搜索的朋友,共同进步. 1.配置schema.xml文件[solr\coll ...
随机推荐
- href和src的区别
虽然一直在用这两个属性,但是一直没有具体的去区分和了解这两个属性的区别,今天就来看看 href标识超文本引用,用在link和a等元素上,href是引用和页面关联,是在当前元素和引用资源之间建立联系 s ...
- Eclipse 通过JPA自动生成注解实体
hibernate是JPA最常用的实现之一,而且hiberante自身也对注释语法进行了支持.现在再不用去看那一堆堆的XML映射了.而且eclipse还提供了从数据库直接生成Entity Class的 ...
- 树莓派与node.js —— onoff、dht
1. 发光二极管 tm-onoff var Gpio = require('tm-onoff').Gpio, led = new Gpio(17, 'out'), button = new Gpio( ...
- ubuntu sublime text key
使用方法 打开 Sublime Text 3 的 “Help”–“Enter Licence”,然后根据版本选择输入下面的注册码. 注册码 所有这些注册码都经过测试(2016-05-12),适用于所有 ...
- 改变html中的内容
$("#id").html() 获取内容 $("#id").html(xiugai) 修改内容
- Chrome程序及数据位置变更到非系统盘
Chrome浏览器在Windows系统上安装过程,没有设置安装位置的步骤,所以默认是安装在C盘的.并且,若Chrome作为主要浏览器使用,随着时间的积累,数据文件会非常多.增加系统盘的负荷. Wind ...
- (15)javaScript入门
什么是javaScript HTML用来做页面的架构,CSS用来做页面样式的布局 javaScript就是用来完成页面用户交互的,JS写的就是叫脚本 js就是弱语言类型,不同类型的时候可以相互转换 j ...
- 实验吧—密码学——WP之 困在栅栏里的凯撒
首先我们研究题目.栅栏:凯撒 还发现一个数字“6”,那么我们很容易就有一个解题思路 对这段字符进行栅栏解密再进行凯撒解密 我们都知道,栅栏解密的关键就是栏数,根据题目中我们发现的信息,这段字符串是12 ...
- nodeJs项目 相关命令
npm install -g cnpm --registry=https://registry.npm.taobao.org npm run dev
- Go Example--工作池
package main import ( "fmt" "time" ) func main() { jobs :=make(chan int,100) res ...