magnetic_scattrelease-4.2.2ticket-1009ticket-1094-headlessticket-1242-2d-resolutionticket-1249
Last change
on this file since 88d2e70 was
0b1a677,
checked in by lewis, 8 years ago
|
Only perform writing on separate thread
Also move reader/writer classes to sascalc
|
-
Property mode set to
100644
|
File size:
1.0 KB
|
Line | |
---|
1 | import os |
---|
2 | import time |
---|
3 | from sas.sascalc.dataloader.readers.red2d_reader import Reader as Red2DReader |
---|
4 | |
---|
5 | class Red2DWriter(Red2DReader): |
---|
6 | |
---|
7 | def write(self, filename, data, thread): |
---|
8 | """ |
---|
9 | Write to .dat |
---|
10 | |
---|
11 | :param filename: file name to write |
---|
12 | :param data: data2D |
---|
13 | """ |
---|
14 | # Write the file |
---|
15 | fd = open(filename, 'w') |
---|
16 | t = time.localtime() |
---|
17 | time_str = time.strftime("%H:%M on %b %d %y", t) |
---|
18 | |
---|
19 | header_str = "Data columns are Qx - Qy - I(Qx,Qy)\n\nASCII data" |
---|
20 | header_str += " created at %s \n\n" % time_str |
---|
21 | # simple 2D header |
---|
22 | fd.write(header_str) |
---|
23 | # write qx qy I values |
---|
24 | for i in range(len(data.data)): |
---|
25 | if thread.isquit(): |
---|
26 | fd.close() |
---|
27 | os.remove(filename) |
---|
28 | return False |
---|
29 | |
---|
30 | fd.write("%g %g %g\n" % (data.qx_data[i], |
---|
31 | data.qy_data[i], |
---|
32 | data.data[i])) |
---|
33 | |
---|
34 | fd.close() |
---|
35 | |
---|
36 | return True |
---|
Note: See
TracBrowser
for help on using the repository browser.