forked from SINGROUP/ProbeParticle_workflow
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathget_data.py
39 lines (30 loc) · 1.02 KB
/
get_data.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
from ase.io.xsf import read_xsf
import numpy as np
import os
class Cd:
"""Context manager for changing the current working directory
:meta private:"""
def __init__(self, new_path, mkdir=False):
self.new_path = os.path.expanduser(new_path)
self.saved_path = None
if not os.path.exists(new_path) and mkdir:
os.mkdir(new_path)
def __enter__(self):
self.saved_path = os.getcwd()
os.chdir(self.new_path)
def __exit__(self, etype, value, traceback):
os.chdir(self.saved_path)
def main(atoms_list):
for i in os.listdir():
if i.startswith('Qo'):
with Cd(i):
for j in os.listdir():
if j.startswith('Amp'):
with Cd(j):
with open("df.xsf", "r") as fio:
data, *_ = read_xsf(fio, read_data=True)
break
break
atoms = atoms_list[0]
atoms.info['box'] = data
return atoms