ABAQUS批处理Inp文件DOS批处理文件实现方法由于可以在命令行窗口启动计算,采用dos批处理文件实现是网上盛传的一种方法,这里主要有两个版本。版本1:callabaqusjob=jobname1callabaqusjob=jobname2callabaqusjob=jobname3callabaqusjob=jobname4这些job是同时进行计算的,并不是一个接一个进行计算。问题就在于abaqusjob=jobname1完成后,计算工作也许并没有完成,但这条命令已经完成,批处理文件直接转到下一个job的运行。这样运行的结果可能是(大部分情况都是如此),你要运行的job在同时计算。版本2:callabaqusjob=jobname1intcallabaqusjob=jobname2intcallabaqusjob=jobname3intcallabaqusjob=jobname4int这里的int其实就是计算执行中的命令参数interactive。在加上int后,只有在当前计算完成后,才会转入下一个模型的计算。计算机自动关闭在学习使用python实现批处理之前,我们先简要介绍一下,dos中如何实现计算机的自动关闭。在dos命令行关闭计算机的命令是:shutdown–s–f–t60-s关闭本地计算机。-f强制关闭计算机。-txx将用于系统关闭的定时器设置为xx秒。上面的设置是60秒。需要说明的两点是,-f参数是用在计算机锁定的时候关闭计算机,如果只使用-s在锁定的时候就不能自动关闭计算机了。另外一点是,如果你看到关机的提示,但又不想马上关闭计算机的话,那只有进入命令行窗口,输入shutdown–a解除关闭命令。几个常用dos下批处理版本好,那现在dos下批处理加关机的程序应该是:callabaqusjob=jobname1intcallabaqusjob=jobname2intcallabaqusjob=jobname3intcallabaqusjob=jobname4intshutdown–s–f–t60如果要加运行参数,和平常一样在第一行加上即可,如下面使用多cpu:callabaqusjob=jobname1cpus=2intcallabaqusjob=jobname2cpus=2intcallabaqusjob=jobname3cpus=2intcallabaqusjob=jobname4cpus=2int如果要删除计算中生成的文件:callabaqusj=nonJt23-2-aintcalldelnonJt23-2-a.comcalldelnonJt23-2-a.datcalldelnonJt23-2-a.filcalldelnonJt23-2-a.mdlcalldelnonJt23-2-a.msgcalldelnonJt23-2-a.prtcalldelnonJt23-2-a.rescalldelnonJt23-2-a.stt如果下一个文件需要restart上一个文件:callabaqusjob=jobname1intcallabaqusjob=jobname2ldjob=jobname1intcallabaqusjob=jobname3ldjob=jobname2intcallabaqusjob=jobname4ldjob=jobname3int使用python实现批处理Python是一种简单易学,功能强大的编程语言,它有高效率的高层数据结构,简单而有效地实现面向对象编程。Python简洁的语法和对动态输入的支持,再加上解释性语言的本质,使得它在大多数平台上的许多领域都是一个理想的脚本语言,特别适用于快速的应用程序开发。在ABAQUS中,python不仅可以实现软件界面的开发,还能够从命令行实现ABAQUS所有功能。这里用以实现批处理的python语言也就是实现job模块的相关命令。先看实现job批处理的python基本代码:fromabaqusConstantsimport*importjobmdb.JobFromInputFile(name='job-1-1',inputFileName='springback_exp_form.inp')mdb.jobs['job-1-1'].submit()mdb.jobs['job-1-1'].waitForCompletion()不明白这几行不要紧,只要知道这几行干什么就可以了,这里简单解释一下。fromabaqusConstantsimport*importjob导入所需的模块和常量。mdb.JobFromInputFile(name='job-1-1',inputFileName='springback_exp_form.inp')该行通过input文件springback_exp_form.inp生成计算任务job-1-1。inputFileName是input文件的名称,而name是计算任务名称,也就是生成的odb等文件的名称。mdb.jobs['job-1-1'].submit()计算文件生成后,提交计算任务。mdb.jobs['job-1-1'].waitForCompletion()中断python文件的执行,等待计算任务的完成。在这里waitForCompletion相当于dos批处理下的参数interactive。如果要在计算完成后自动关机,加入以下python代码:importos,time,syso=c:\windows\system32\shutdown-s-f-t60os.system(o)在python实现批处理代码中也可以加入命令行中的各个参数,如numCpus代表使用的cpu数量,explicitPrecision是设定使用explicit模块进行计算的精度等等。下面的代码表示计算任务采用2个cpu,2个domain:mdb.JobFromInputFile(name='job-1-1',inputFileName='springback_exp_form.inp',numCpus=2,numDomains=2)当然还有更多的其他参数,具体可以参考ABAQUSScriptingReferenceManual。这样我们就有一个批处理python范本了:fromabaqusConstantsimport*importjobmdb.JobFromInputFile(name=''jobname1',inputFileName='jobname1.inp')mdb.jobs['jobname1'].submit()mdb.jobs['jobname1'].waitForCompletion()mdb.JobFromInputFile(name=''jobname2',inputFileName='jobname2.inp')mdb.jobs['jobname2'].submit()mdb.jobs['jobname2'].waitForCompletion()importos,time,syso=c:\windows\system32\shutdown-s-f-t60os.system(o)如何执行比如说将上面的python文件保存为python-bat.py。打开ABAQUSCommand窗口,进入python-bat.py所在目录,输入以下命令即可运行批处理文件。abaquscaenogui=python-bat.py