python处理地震sac数据_试用python读取地震波形的二进制SAC文件

sac文件比较简单,不过有些设置没有处理,只是单纯的读取并绘图。

代码:

import struct

import pylab

class sacfile_wave:

def read(self,sFile):

#sFile='e:\\10.sac'

f=open(sFile,'rb')

hdrBin=f.read(632)

sfmt='f'*70+'I '*40+'8s '*22+'16s';

hdrFmt=struct.Struct(sfmt)

self.m_header=hdrFmt.unpack(hdrBin)

npts=int(self.m_header[79])

fmt_data='f'*npts

dataFmt=struct.Struct(fmt_data)

dataBin=f.read(4*npts)

f.close()

self.m_data=dataFmt.unpack(dataBin)

print "data len:",len(self.m_data)

def draw(self,sImageFile):

npts=len(self.m_data)

xd=range(1,npts+1)

pylab.figure(1)

pylab.plot(xd,self.m_data,linewidth=0.3)

pylab.savefig(sImageFi

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值