-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathModflow-Q1.py
49 lines (44 loc) · 2.18 KB
/
Modflow-Q1.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
40
41
42
43
44
45
46
47
48
49
# -*- coding: utf-8 -*-
"""
Created on Wed May 10 21:26:39 2023
@author: Zahra Soleimanzade
"""
##second-part runnig modflow with added Q
import shutil
# use copyfile()
shutil.copyfile("E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\Q-1.txt","E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\4202-Transient-calib8.wel")
import flopy
first = flopy.modflow.Modflow.load("E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\4202-Transient-calib8.mfn", version='mf2k',exe_name="E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\mf2k.exe", verbose =True , load_only=None , forgive=False , check =False )
flopy.run_model(exe_name="E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\mf2k.exe", namefile="E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\4202-Transient-calib8.mfn")
#getting heads from output files
hdobj = flopy.utils.HeadFile("E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\4202-Transient-calib8.hed")
Heads = hdobj.get_data(kstpkper=None, mflay=0 , totim=2190)
print(Heads)
time=hdobj.get_times()
print(time)
#import numpy
#a = numpy.asarray(Heads)
#numpy.savetxt("E:\\zargolooo\\Thesis\\python-Thesis\\Head-1.csv", a, delimiter=",")
with open("E:\\zargolooo\\Thesis-04-19\\test code python\\KIJ.txt") as f:
lines = f.readlines()
first = list(list(map(int, line.split())) for line in lines)
for i in first:
i[0] = i[0] - 1
i[1] = i[1] - 1
i[2] = i[2] - 1
print(first)
idx = []
for x in first:
idx.append(tuple(x))
print(idx)
###############
#using extracted IJK in idx as variable
finalHead=[]
for j in idx:
hdobj = flopy.utils.HeadFile("E:\\zargolooo\\Thesis-04-19\\python-Thesis\\4202-Transient-calib8_MODFLOW\\Out_Mf2k\\4202-Transient-calib8.hed")
Heads= hdobj.get_ts(idx = j)
finalHead.append(Heads[72][1])
print(finalHead)
import numpy
a = numpy.asarray(finalHead)
numpy.savetxt("E:\\zargolooo\\Thesis-04-19\\python-Thesis\\Head-1.csv", a, delimiter=",")