This question already has an answer here:
Python: return values from a loop without breaking out
                                
                                    (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