0

我有一个文本文件,其中列出了一组员工的姓名、身份证号、性别和工作年限。第一行包含员工人数。它被称为employees.txt。这里是:

7

约翰

能源部

33

272838

玛丽

约翰逊

38

3849383

F

奥派

6

839293

小姐

4

238392

F

约翰

布拉

28

834282

阿米莉亚

斯宾

2

5789812

F

谢恩

卡森斯蒂恩

2

567891


我想将这些信息组织成一个字典列表,然后找到所有女性员工并打印出她们的名字和姓氏。我可以让字典列表工作,但是当我尝试查找并打印出女性员工的姓名时出现错误。这是我的代码:

def employee_write(file):
    employee_dict = {}
    employee_dict["First"] = file.readline().strip()
    employee_dict["Last"] = file.readline().strip()
    employee_dict["Experience"] = file.readline().strip()
    employee_dict["ID"] = file.readline().strip()
    employee_dict["Gender"] = file.readline().strip()
    return employee_dict

def female_print(x2):
    for term in x2:
        for word in employee_dict:
            if employee_dict["Gender"] == "F":
                print(employee_dict["First"])
                print(employee_dict["Last"])

def main():
    file = open("employees.txt", "r")
    n = int(file.readline())
    x1 = employee_write(file)
    employee_list = []
    for i in range(n):
        employee_list.append(x1)
        x2 = employee_list
    print(x2)
    female_print(x2)

main()

我的错误是什么?female_print() 函数不起作用,因为它表示未定义名称“employee_dict”。有什么问题?

4

3 回答 3

1

我很难理解你的变量命名和用法,所以我简化了一点:

def employee_write(file):
    employee_dict = {}
    employee_dict["First"] = file.readline().strip()
    employee_dict["Last"] = file.readline().strip()
    employee_dict["Experience"] = file.readline().strip()
    employee_dict["ID"] = file.readline().strip()
    employee_dict["Gender"] = file.readline().strip()
    return employee_dict

def female_print(employee_list):
    for employee in employee_list:
        if employee["Gender"] == "F":
            print(employee["First"])
            print(employee["Last"])

def main():
    file = open("employees.txt", "r")
    n = int(file.readline())
    employee_list = []
    for i in range(n):
        employee_list.append(employee_write(file))
    print(employee_list)
    female_print(employee_list)

main()

产生

[{'Gender': 'M', 'Last': 'Doe', 'ID': '272838', 'Experience': '33', 'First': 'John'}, {'Gender': 'F', 'Last': 'Johnson', 'ID': '3849383', 'Experience': '38', 'First': 'Mary'}, {'Gender': 'M', 'Last': 'Dog', 'ID': '839293', 'Experience': '6', 'First': 'Opie'}, {'Gender': 'F', 'Last': 'Dog', 'ID': '238392', 'Experience': '4', 'First': 'Missy'}, {'Gender': 'M', 'Last': 'Bla', 'ID': '834282', 'Experience': '28', 'First': 'John'}, {'Gender': 'F', 'Last': 'Spien', 'ID': '5789812', 'Experience': '2', 'First': 'Amelia'}, {'Gender': 'M', 'Last': 'CasenStien', 'ID': '567891', 'Experience': '2', 'First': 'Shane'}]
Mary
Johnson
Missy
Dog
Amelia
Spin

那是你要的吗?

于 2013-03-15T20:31:10.673 回答
0

main中,函数employee_write, (可能应该被调用employee_read)只被调用一次

尝试这样的事情:

In [1]: with open('employees.txt', 'r') as ef:
    txt = ef.read()
   ...:     

In [2]: lines = txt.split()

In [3]: records = [lines[i:i+5] for i in xrange(1, len(lines), 5)]

In [4]: records
Out[4]: [['John', 'Doe', '33', '272838', 'M'], ['Mary', 'Johnson', '38', '3849383', 'F'], ['Opie', 'Dog', '6', '839293', 'M'], ['Missy', 'Dog', '4', '238392', 'F'], ['John', 'Bla', '28', '834282', 'M'], ['Amelia', 'Spien', '2', '5789812', 'F'], ['Shane', 'CasenStien', '2', '567891', 'M']]

In []: for r in records:
    print r
   ....:     
['John', 'Doe', '33', '272838', 'M']
['Mary', 'Johnson', '38', '3849383', 'F']
['Opie', 'Dog', '6', '839293', 'M']
['Missy', 'Dog', '4', '238392', 'F']
['John', 'Bla', '28', '834282', 'M']
['Amelia', 'Spien', '2', '5789812', 'F']
['Shane', 'CasenStien', '2', '567891', 'M']

注意:此代码假定输入文件的格式正确!

于 2013-03-15T20:43:40.527 回答
0

您在这里有两个(主要)问题。一方面,您实际上并没有阅读整个文件。您正在读取第一条记录(作为 x1),然后将该记录附加到列表中 N 次。您可以从印刷品中看到您只获得了一条记录。

此外,您的 print_female 函数引用了一个不存在的变量“employee_dict”——您可能需要在某处定义它。也许您的意思是使用“术语”?这会引发堆栈跟踪。

如果你解决了这两个问题,你的代码的基本前提是健全的。

于 2013-03-15T20:34:58.020 回答