python程序设计某班有 74 名同学,名单在Name.txt文件中,Python课的某次考勤记录存放在1.csv当中,此二文件均保存在桌面的“file”文件夹当中(保存路径视现场情况掌握),编写程序求出该次Python课缺勤同学的名单。

时间: 2023-09-07 08:04:12 浏览: 85
### 回答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的文件,其中包含了缺勤的同学名单。

最新推荐

recommend-type

Python将列表数据写入文件(txt, csv,excel)

主要介绍了Python将列表数据写入文件(txt, csv,excel),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

在Python3.74+PyCharm2020.1 x64中安装使用Kivy的详细教程

主要介绍了在Python3.74+PyCharm2020.1 x64中安装使用Kivy的详细教程,本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

在python3中实现查找数组中最接近与某值的元素操作

今天小编就为大家分享一篇在python3中实现查找数组中最接近与某值的元素操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

使用python获取csv文本的某行或某列数据的实例

下面小编就为大家分享一篇使用python获取csv文本的某行或某列数据的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python将一个CSV文件里的数据追加到另一个CSV文件的方法

今天小编就为大家分享一篇Python将一个CSV文件里的数据追加到另一个CSV文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。