如何在列表列表中搜索列表

时间:2013-11-07 23:17:35

标签: python list search

如何具体搜索列表中的特定列表:

假设我有一个包含许多其他列表的列表grid_list,我想通过grid_list搜索以找到其中一个具体我怎么能这样做?这是我认为应该工作的代码 犯规:

import sys #sys has been imported to take in user input
import random #random has been imported to generate random numbers to store the ants food in in the grid

#grid list is a generated list used to store grid values
grid_list = []
grid_size=0 #grid size is a variable that is assigned a value in function space and used in other functions, has default value of zero
ant_position="" #ants current position in grid used in more than one function
food_location="" #foods position in grid used in more than one function

#function for setting up a grid
def space():

print("please enter the size of the square grid you want")
#grid size is assigned by user input
global grid_size 
grid_size = int(sys.stdin.readline())
#embedded for loops to set up a list that stores grid points
for count in range(0,grid_size):
    x_number= count+1 #x number is the x number of the cell in the grid
    for count in range(0,grid_size):
        y_number= count+1 # y number is the y number of the cell in the grid
        grid_list.append([x_number,y_number,0,0,0]) #this stores a list within a list, so the first two values of the second list represent the co-ordinates of the cell the last three represent pheromone, food location, ant location (both food and ant location take value of one if either are in there)

def locations():

global food_location

food_location_x = (random.randint(1,grid_size)) #gives the x value of the cell the food is stored in
food_location_y = (random.randint(1,grid_size)) #gives the y value of the cell the food is stored in
food_location = [food_location_x,food_location_y,0,0,0] #gives the full location of the food and will use this to in other functions to reference the grid list
for count in range(0,4):
    grid_list[[grid_list.index([food_location])][count]] = [food_location_x,food_location_y,0,1,0]
print(grid_list[grid_list.index(food_location)])

此代码设置一个包含许多其他列表的列表(空间函数),然后更改列表中的一个列表(grid_list)以表示它包含食物。

然而,不是这个工作,我得到一个值错误,说[2,1,0,0,0]不在列表中或代码给出的任何其他网格值(2和1可以被任何正整数替换在这种情况下)。有人可以向我解释我如何更改它以便正确搜索它吗?

3 个答案:

答案 0 :(得分:1)

我可以看到一个错误:

grid_list.index([food_location])

您将food_location放入列表中。但food_location 已经一个列表,所以现在列表中有一个列表。执行grid_list.index(that)时,它会告诉您grid_list中没有双重嵌套列表。

老实说,看起来你正在做一个非常时髦的方法来获得grid_list的随机抽样。您应该使用random.choicerandom.sample分别从您的收藏中获取一个或多个随机元素。

答案 1 :(得分:1)

此代码中有两个错误。第一个,先前由roippi指出,是在搜索之前将food_location放入列表中。第二个是你做了四次相同的事情。您正在搜索[x,y,0,0,0],替换它,然后在列表中搜索相同的[x,y,0,0,0]。由于您刚刚更换了该元素,因此它不再存在,您将收到您所看到的错误。

正如roippi所说,获得4个职位取代的更好方法是使用

random.sample(grid_list, 4)

并修改返回的四个列表中的每一个,以便第四个元素为1. random.sample将返回grid_list中的相同的列表,因此修改这些列表的元素将修改它们在grid_list中也是如此。

答案 2 :(得分:0)

您将二维数组表示为列表列表,并且您正在尝试搜索某个项目。您根本无法使用grid_list.index()进行此类搜索。 grid_list中的项目是您网格的列,因此grid_list.index(item)正在将项目与整个列进行比较,因此找不到匹配项。

我建议定义一个可以进行所需搜索的功能。类似的东西:

def find_in_grid(grid, item_to_find):
    """search for a given item in a grid

    If found, the indexes (x, y) are returned. Otherwise, returns None.
    """
    for row in range(len(grid)):
        for column in range(len(grid[row])):
            if grid[row][column] == item_to_find:
                return (row, column)
    return None # item not found in the grid

当然,定义一个简单的Grid类并给它一个find()index()方法会更好。