This question already has an answer here:
Python: return values from a loop without breaking out
(1个答案)
5年前关闭。
我有以下代码:
我希望所有值都在循环之外,而不仅仅是最后一个/第一个。如果我注释
(1个答案)
5年前关闭。
我有以下代码:
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
from scipy.special import *
import matplotlib.pyplot as plt
import numpy as np
from math import *
import csv
## Globale Variablen ##
rhof = 1000 # Dichte Flüssigkeit [kg/m³]
lameu = 11.2*10**9 # Lamé-Parameter, undrained [GPa]
lame = 8.4*10**9 # Lamé-Parameter, drained [GPa]
pi # durch Pythonmodul "math" gegeben
alpha = 0.65 # Biot-Willis-Koeffizient
G = 8.4*10**9 # Schermodul [GPa]
k = 1.0e-15 # Permeabilität [m²] bzw. [Darcy]
eta = 0.001 # Viskosität des Fluids [Pa*s]
## Berechnung der Parameter ##
kappa = k/eta
c = ((kappa*(lameu-lame)*(lame+2*G))/((alpha**2)*(lameu+2*G)))
## Wertebereich ##
xmin = 0
xmax = 50
xsteps = 1
x = np.arange(xmin,xmax,xsteps)
ymin = 0
ymax = 50
ysteps = 1
y = np.arange(ymin,ymax,ysteps)
X, Y = np.meshgrid(x,y)
## Klassendefinition ##
class Bohrloch(object):
loch_zaehler = 0
def __init__(self, xlage, ylage, tstart, q): # Funktion, um BL zu erzeugen
self.xlage = xlage # x-Lage der Bohrung
self.ylage = ylage # y-Lage der Bohrung
self.tstart = tstart # Start der Injektion/Produktion
self.q = q # Fluidmenge
######################### Druck ###############################################
def getPressure(self, t):
if (t-self.tstart<0):
return ()
print "Startpunkt liegt außerhalb des Förderzeitraumes!"
else:
for x in range (xmin, xmax, xsteps):
for y in range (ymin,ymax,ysteps):
self.r = sqrt((x-self.xlage)**2+(y-self.ylage)**2)
self.P = (self.q/(rhof*4*pi*kappa))*(expn(1,self.r**2/(4*c*(t-self.tstart))))
self.z = self.P/1e6 #= self.P/1e6
#print self.z
return self.z
我希望所有值都在循环之外,而不仅仅是最后一个/第一个。如果我注释
return self.z
和取消注释print self.z
,则显示所有值,但我想返回所有值。我读到有关yield
可能性的信息,但我并不十分了解。我正在寻找最简单的解决方案;任何帮助将不胜感激! 最佳答案
创建一个列表,将每个项目附加到该列表,然后在函数末尾将其返回。
def getPressure(self, t):
if (t-self.tstart<0):
return ()
print "Startpunkt liegt außerhalb des Förderzeitraumes!"
else:
result = []
for x in range (xmin, xmax, xsteps):
for y in range (ymin,ymax,ysteps):
self.r = sqrt((x-self.xlage)**2+(y-self.ylage)**2)
self.P = (self.q/(rhof*4*pi*kappa))*(expn(1,self.r**2/(4*c*(t-self.tstart))))
self.z = self.P/1e6 #= self.P/1e6
result.append(self.z)
return result
10-04 18:05