
标星★公众号 爱你们♥
——还没找到组织?
CAE仿真与数值模拟公众号已设立交流群, 赶快加入和小伙伴们聊聊吧!加群方法:先加CAE仿真与数值模拟小编为好友(微信号 stokisyd ),发送消息“CAE群”
最近写了一个简单的python读取abaqus结果中的场输出数据,就在这里简单的讲一下整个流程。后续采用abaqus读取场输出结果应用也挺广泛。整个过程的流程图可以用下图来概括,因为不是计算机专业,考虑没那么细致,很多python函数也是即查即用,当然程序后续根据要求也可以不断更改。

下面就从这两个方面按照图片步骤讲解一下这个小程序:
1# -*- coding: utf-8 -*-2from odbAccess import *3from abaqusConstants import*4import csv 1###1.打开文件### 2 3#定义文件路径 4OdbFilePath='E:/temp/kehu11-python/09g-B5.odb' 5#打开Odb文件 6myodb=openOdb(OdbFilePath) 7 8###2.读取场输出结果### 910#读取的是场输出DAMAGEC和DAMAGET结果,damagecField是自定义,数据类型是后面赋予的#11#简单说下python语言,如下,很直接了当,.连接就像中国.湖北.武汉.华科一样#12#读取结果里Step-earthquake的最后一帧的DAMAGEC#13 damagecField=myodb.steps['Step-earthquake'].frames[-1].fieldOutputs['DAMAGEC']14 damagetField=myodb.steps['Step-earthquake'].frames[-1].fieldOutputs['DAMAGET']1516 ###3.保存到数组###1718#场输出是一个大的类型,val1是它的所有结果#19val1=damagecField.values20#定义两个数组,分别存储单元编号和对应的数值#21val1nodeLabel=[]22val1DamagecData=[]23#用一个简单的循环将场输出中每一个结果的对应数值与单元编号写入到上述数组#24for v1 in val1: 25 val1nodeLabel.append(v1.elementLabel)26 val1DamagecData.append(v1.data)27#将数组排序,abaqus场输出的数值并非按照单元编号一个接一个,经常有跳动,所以需要排序#28#下面的排序算法百度得到,就是将两个数组一一对应排序,作用如下#29#1,2,3,7,8,9,4,5,6对应a,b,c,h,i,j,e,f,排序后30#1,2,3,4,5,6,7,8,9对应a,b,c,d,e,f,g,h,i,j31Z1=zip(val1nodeLabel,val1DamagecData)32Z1=sorted(Z1)33sortedval1nodeLabel,sortedval1DamagecData=zip(*Z1)3435##上面输出的只是damagec的对应结果,下面输出damaget对应结果# 36val2nodeLabel=[]37val2DamagetData=[]38val2=damagetField.values39for v2 in val2: 40 val2nodeLabel.append(v2.elementLabel)41 val2DamagetData.append(v2.data)42Z2=zip(val2nodeLabel,val2DamagetData)43Z2=sorted(Z2)44sortedval2nodeLabel,sortedval2DamagetData=zip(*Z2)4546###4.关闭文件###4748myodb.close() 1###1.打开文件### 2 3#数据一般保存方式为csv,简单的可以用txt,这里方便后处理采用csv文件,定义文件路径# 4CsvFilePath='https://www.gofarlic.com/damge.csv' 5#打开csv文件 6csvFile=open(CsvFilePath,'wb') 7 8 ###2.写入数据### 910writer=csv.writer(csvFile)11#写入抬头#12writer.writerow(['NodeLabel','DamagecData','DamagetData'])13#获取数组的长度#14#lenth(sortedval1nodeLabel)#这里太多我就只输出1000个单元数据#15 lenth=100016#逐行写入到csv文件中17i=018while i<=lenth:19 writer.writerow([sortedval1nodeLabel[i],sortedval1DamagecData[i],20 sortedval2DamagetData[i]])21 i=i+12223###3.关闭文件###2425csvFile.close() 最终得到一个csv文件,提取结果如下图
数据值为0,是因为其计算时间太长,等了一晚上才计算到第9秒还没有发生损伤,因此其数值均为0。 提取较多的结果可能是常见的应力应变,节点位移等,不过方法都是一样的,改动起来也较为简单。有兴趣的朋友不妨动手尝试一下。 使用Python脚本确实可以大大减轻我们的工作负担,毕竟认识苦短,而且学起来很简单,注重一个对Python以及abaqus的理解,后续很多函数也都是现搜现用。关于Python在ABAQUS中的应用,推荐曹金凤老师的书,可以用来当作工具书,随时需要了去翻一下,给我们提供指导。基本上也不用专门去学习下Python,书里附带的Python语言基础也够用了。如果大家有啥需要使用Python脚本的地方,也可以过来咨询我。

更多精彩内容推荐阅读:
CAE仿真与数值模拟微信公众号,主要介绍CAE仿真与数值模拟的知识与应用。通过论坛,博客,论文,案例等为大家带来知识食粮。仿真软件:abaqus、ansys、flunet、comsol、hypermesh、moldflow等,涉及领域有机械材料土木物理等。
你点的每个“在看”,我们都认真当成了喜欢
免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删