2017-06-01 145 views
0

我有一個項目,我正在研究這個項目,需要我根據從Excel文件中拉出的值,將項目放置在預定義的價格層中。除了最後一部分之外,我的腳本中還有其他一切工作。從列表中返回值基於2個其他列表元素之間的值返回值

我希望能夠做的是建立名單(不停留在是否有更好/更有效的選擇數據結構)的列表,請檢查該值i[0]i[1],並返回i[2]之間。

例子是:

my_value = 22.99 
[[0],[24.99],['0-24.99'],[25,49.99,'25-49.99]......] 

所需的輸出:'0-24.99'

編輯:

現在,我回到我的電腦,我寫出來的代碼,試圖拉這個關閉。

這些函數用於計算並匹配層。

#define functions 
    #calculate Eligible Average Selling Price 
    def asp(x,y): 
     if float(y)==0: 
      return 0 
     else: 
      return float(x)/float(y) 
    #Search Tiers Dictionary and return undefined if tier does not exist 
    def inTier(x,y,z): 
     for t in Tiers[x]: 
      if float(t[0]) <= asp(y,z) <= float(t[1]): 
       return t[2] 
      else: 
       return 'Tier Undefined' 

這是我正在循環匹配層的字典。

Tiers= {'Desktop':[[0, 24.99, '0-24.99'],[25, 49.99, '25-49.99'],[50, 74.99, '50-74.99'],[75, 99.99, '75-99.99'],[100, 124.99, '100-124.99'],[125, 149.99, '125-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 499.99, '300-499.99'],[500, 749.99, '500-749.99'],[750, 999.99, '750-999.99'],[1000, 1999.99, '1000-1999.99'],[2000, 2999.99, '2000-2999.99'],[3000, 9999.99, '3000-9999.99']],'Chair':[[0, 24.99, '0-24.99'],[25, 49.99, '25-49.99'],[50, 74.99, '50-74.99'],[75, 99.99, '75-99.99'],[100, 124.99, '100-124.99'],[125, 149.99, '125-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 499.99, '300-499.99'],[500, 749.99, '500-749.99'],[750, 999.99, '750-999.99'],[1000, 1999.99, '1000-1999.99'],[2000, 2999.99, '2000-2999.99'],[3000, 9999.99, '3000-9999.99']],'Gear':[[0, 9.99, '0-9.99'],[10, 24.99, '10-24.99'],[25, 49.99, '25-49.99'],[50, 74.99, '50-74.99'],[75, 99.99, '75-99.99'],[100, 124.99, '100-124.99'],[125, 149.99, '125-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 349.99, '300-349.99'],[350, 399.99, '350-399.99'],[400, 499.99, '400-499.99'],[500, 749.99, '500-749.99'],[750, 999.99, '750-999.99'],[1000, 1999.99, '1000-1999.99'],[2000, 2999.99, '2000-2999.99'],[3000, 9999.99, '3000-9999.99']],'Laptop':[[0, 49.99, '0-49.99'],[50, 99.99, '50-99.99'],[100, 149.99, '100-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 349.99, '300-349.99'],[350, 399.99, '350-399.99'],[400, 449.99, '400-449.99'],[450, 549.99, '450-549.99'],[550, 649.99, '550-649.99'],[650, 749.99, '650-749.99'],[750, 999.99, '750-999.99'],[1000, 4999.99, '1000-1999.99'],[2000, 6999.99, '2000-6999.99']],'Printer':[[0, 24.99, '0-24.99'],[25, 49.99, '25-49.99'],[50, 74.99, '50-74.99'],[75, 99.99, '75-99.99'],[100, 124.99, '100-124.99'],[125, 149.99, '125-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 499.99, '300-499.99'],[500, 749.99, '500-749.99'],[750, 999.99, '750-999.99'],[1000, 1999.99, '1000-1999.99'],[2000, 2999.99, '2000-2999.99'],[3000, 9999.99, '3000-9999.99']],'Tablet':[[0, 49.99, '0-49.99'],[50, 99.99, '50-99.99'],[100, 149.99, '100-149.99'],[150, 199.99, '150-199.99'],[200, 249.99, '200-249.99'],[250, 299.99, '250-299.99'],[300, 349.99, '300-349.99'],[350, 399.99, '350-399.99'],[400, 449.99, '400-449.99'],[450, 549.99, '450-549.99'],[550, 649.99, '550-649.99'],[650, 749.99, '650-749.99'],[750, 999.99, '750-999.99'],[1000, 1999.99, '1000-1999.99'],[2000, 4999.99, '2000-4999.99']]} 

,這裏是其中值正被從列表行計算成一個列表行

row=[row[0],row[1].split(" ")[1],row[2].split(" ")[1],int(re.findall(r'\d+', row[3])[0]),row[4],row[5],row[6],asp(row[5],row[6]),inTier(row[0],row[5],row[6])] 

和示例行被返回「層未定義」:

['Gear', 'REGION 27 SOUTHEAST', 'DISTRICT 7 E ATL', 'LOGANVILLE GA (6852)', 'WNDA3100 RANGEMAX', '32.99', '1'] 

在一般來說,看起來只有正確匹配的唯一層次是列表字典值列表中的第一個。

+1

爲什麼在不同的子陣列第3,但下一個組是在一個單獨的子數組中? – Barmar

+0

'如果我[0] <= my_value <= i [1]:return i [2]' – Barmar

+0

@Barmar在我的方面缺乏清晰度。在循環中,它將以類似於i的方式開始: –

回答

0

我假設你的列表中有一個錯字,你的意思是寫:

tiers = [[0,24.99,'0-24.99'],[25,49.99,'25-49.99]......] 

然後你只需遍歷它們:

for tier in tiers: 
    if tier[0] <= my_value <= tier[1]: 
     selected_tier = tier[2] 
     break 
+0

明白了。如果我需要循環使用500,000個潛在的批量值,這是否是最好的方法? –

+0

像這些例子一樣,所有層次的範圍是25嗎?如果是,你可以分開。 – Barmar

+0

不會,他們會有所不同 –