def test_createRESPFromXSEED(self): """ Tests RESP file creation from XML-SEED. """ # 1 # parse Dataless SEED filename = os.path.join(self.path, 'dataless.seed.BW_FURT') sp1 = Parser(filename) # write XML-SEED with NamedTemporaryFile() as fh: tempfile = fh.name sp1.write_XSEED(tempfile) # parse XML-SEED sp2 = Parser(tempfile) # create RESP files sp2.get_RESP() # 2 # parse Dataless SEED filename = os.path.join(self.path, 'arclink_full.seed') sp1 = Parser(filename) # write XML-SEED with NamedTemporaryFile() as fh: tempfile = fh.name sp1.write_XSEED(tempfile) # parse XML-SEED sp2 = Parser(tempfile) # create RESP files sp2.get_RESP()
def test_splitStationsDataless2XSEED(self): """ Test case for writing dataless to XSEED with multiple entries. """ filename = os.path.join(self.path, 'dataless.seed.BW_DHFO') parser = Parser() parser.read(filename) with NamedTemporaryFile() as fh: tempfile = fh.name # this will create two files due to two entries in dataless parser.write_XSEED(tempfile, split_stations=True) # the second file name is appended with the timestamp of start # period os.remove(tempfile + '.1301529600.0.xml')
def dataless2xseed(filename, options): files = [] for item in filename: files.extend(glob(item)) outdir = False outfile = False if options.output: if os.path.isdir(options.output): outdir = options.output elif len(files) > 1: msg = 'More than one filename is given.' + os.linesep msg += '\t--output argument will not be used.\n' sys.stdout.write(msg) else: outfile = options.output if options.verbose: msg = 'Found %s files.' % len(files) + os.linesep sys.stdout.write(msg) for file in files: if not os.path.isfile(file): continue f = open(file, 'rb') if f.read(7)[6:] != b'V': if options.verbose: msg = 'Skipping file %s' % file msg += '\t-- not a Dataless SEED file' + os.linesep sys.stdout.write(msg) f.close() continue f.close() if outdir: output = os.path.join(outdir, os.path.basename(file) + os.extsep + 'xml') elif outfile: output = outfile else: output = os.path.basename(file) + os.extsep + 'xml' if options.verbose: msg = 'Parsing file %s' % file + os.linesep sys.stdout.write(msg) try: parser = Parser(file, debug=options.debug) parser.write_XSEED(output, version=str(options.version), split_stations=options.split_stations) except Exception as e: if options.debug: raise msg = '\tError parsing file %s' % file + os.linesep msg += '\t' + str(e) + os.linesep sys.stderr.write(msg)