python程序设计某班有 74 名同学,名单在Name.txt文件中,Python课的某次考勤记录存放在1.csv当中,此二文件均保存在桌面的“file”文件夹当中(保存路径视现场情况掌握),编写程序求出该次Python课缺勤同学的名单。
时间: 2023-09-07 16:04:12 浏览: 154
用文件存储10个学生的姓名、学号、手机号、地址,可通过姓名或者学号查找
5星 · 资源好评率100%
### 回答1:
可以使用Python中的pandas库来读取csv文件,然后使用set的差集操作来获得缺勤同学的名单。以下是示例代码:
```python
import pandas as pd
# 读取文件
names = pd.read_csv('Desktop/file/Name.txt', header=None, names=['name'])
attendance = pd.read_csv('Desktop/file/1.csv')
# 将名字转成set类型
names_set = set(names['name'])
# 将出席同学的名字转成set类型
attendance_set = set(attendance['姓名'])
# 获取缺勤同学的名单
absentees = names_set - attendance_set
# 打印缺勤同学的名单
print(absentees)
```
需要注意的是,文件路径要根据实际情况进行修改。
### 回答2:
首先,我们需要读取Name.txt文件中的名单,可以使用`open()`函数打开文件并使用`readlines()`方法读取每行内容,将名单存储在一个列表中。
```python
names = []
with open('file/Name.txt', 'r') as f:
lines = f.readlines()
for line in lines:
names.append(line.strip())
```
接下来,我们将读取1.csv文件中的考勤记录,同样使用`open()`函数打开文件,并使用`csv`模块中的`reader`方法读取每行内容。为了方便查找缺勤同学,我们将考勤记录存储在一个字典中,键为学生姓名,值为出勤情况('1'表示出勤,'0'表示缺勤)。
```python
import csv
attendance = {}
with open('file/1.csv', 'r') as f:
reader = csv.reader(f)
for row in reader:
attendance[row[0]] = row[1]
```
最后,我们可以遍历名单中的学生姓名,如果该学生在考勤记录中出勤情况为'0',则说明该学生缺勤。我们可以将缺勤学生的姓名输出。
```python
absentees = []
for name in names:
if attendance.get(name) == '0':
absentees.append(name)
print("缺勤同学的名单:")
for student in absentees:
print(student)
```
这样,程序就可以求出该次Python课缺勤同学的名单。
### 回答3:
首先,我们需要读取Name.txt文件和1.csv文件中的数据。对于Name.txt文件,我们可以使用Python的内置open()函数和readlines()方法来读取文件中的每一行数据。对于1.csv文件,我们可以使用Python的csv模块中的csv.reader()函数来读取文件中的内容。
之后,我们需要将Name.txt文件中的名单存储在一个列表中,方便后续的比较。我们可以使用一个空列表来存储这些名字。
接下来,我们需要读取1.csv文件中的数据并找出缺勤的同学名单。可以通过循环遍历1.csv文件中的每一行,获取每个同学的名字,然后判断该名字是否存在于我们之前创建的名单列表中。如果不存在,就说明该同学缺勤,将其名字添加到一个缺勤同学名单的列表中。
最后,将缺勤同学名单保存为一个新的文件,可以使用Python的内置open()函数和write()方法来实现。
以下是示例代码:
```python
import csv
def main():
# 读取Name.txt文件中的名单
name_list = []
with open("file/Name.txt", "r") as name_file:
names = name_file.readlines()
for name in names:
name_list.append(name.strip())
# 读取1.csv文件中的数据并找出缺勤同学名单
absent_list = []
with open("file/1.csv", "r") as csv_file:
csv_reader = csv.reader(csv_file)
for row in csv_reader:
name = row[0]
if name not in name_list:
absent_list.append(name)
# 将缺勤同学名单保存为新文件
with open("file/Absent.txt", "w") as absent_file:
for name in absent_list:
absent_file.write(name + "\n")
if __name__ == "__main__":
main()
```
上述代码中的程序假设Name.txt文件和1.csv文件保存在名为"file"的文件夹中,并且文件夹位于桌面上。如果实际保存的路径不同,需要根据实际情况进行修改。代码执行完毕后,会在"file"文件夹中生成一个名为Absent.txt的文件,其中包含了缺勤的同学名单。
阅读全文