python对文件的_python 对文件操作

#!/usr/bin/env python#-*- coding:utf-8 -*-

defFind(class_name):

class_list=[]

tag=False

with open(‘data‘, ‘r‘, encoding=‘utf8‘) as f:for line inf:if line.strip() == ‘班级:{0}班‘.format(class_name.strip()):

class_list.append(line)

tag=Truecontinue

if tag and line.find(‘班级:‘) !=0:

class_list.append(line)if line.find(‘班级:‘) ==0:

tag=Falsereturnclass_list;defAdd(dic):#{ ‘班级‘:‘191‘,‘学生‘:[{‘姓名‘:‘张三‘,‘学号‘:‘2018001‘,‘年龄‘:18,‘性别‘:‘男‘},{‘姓名‘:‘李四‘,‘学号‘:‘2018002‘,‘年龄‘:21,‘性别‘:‘男‘},{‘姓名‘:‘小花‘,‘学号‘:‘2018003‘,‘年龄‘:18,‘性别‘:‘女‘},{‘姓名‘:‘小红‘,‘学号‘:‘2018004‘,‘年龄‘:33,‘性别‘:‘女‘}]}

class_obj =eval(dic)

class_name= class_obj[‘班级‘]

class_list=Find(class_name)if len(class_list) >0:print(‘系统中已经存在班级[%s]。‘ %(class_name))returnwith open(‘data‘, ‘a+‘, encoding=‘utf8‘) as f:

f.write(‘\n班级:%s班‘ %(class_name))for student in class_obj[‘学生‘]:

f.write(‘\n 姓名:{0} 学号:{1} 年龄:{2} 性别:{3}‘.format(student[‘姓名‘], student[‘学号‘], student[‘年龄‘],

student[‘性别‘]))print(‘添加成功!‘)defUpdate(dic):

class_obj=eval(dic)

class_name= class_obj[‘班级‘]

class_list=Find(class_name)if len(class_list) ==0:print(‘没有查询到该班级信息。‘)returnDelete(class_name)

Add(dic)print(‘更新成功!‘)defDelete(class_name):

class_list=Find(class_name)if len(class_list) ==0:print(‘没有查询到该班级信息。‘)returnclass_list=[]

tag=False

with open(‘data‘, ‘r‘, encoding=‘utf8‘) as old_file:for line inold_file:if line.strip() == ‘班级:{0}班‘.format(class_name.strip()):

tag=Truecontinue

else:if tag and line.find(‘班级:‘) !=0:continue

if line.find(‘班级:‘) ==0:

tag=False

class_list.append(line)

with open(‘data‘, ‘w‘, encoding=‘utf8‘) as new_file:for line inclass_list:

new_file.write(line)print(‘删除成功!‘)if __name__ == ‘__main__‘:whileTrue:print(‘\n1、查询 2、修改 3、添加 4、删除‘)

operation= input(‘请输入操作:‘)if (operation == ‘1‘):

class_name= input(‘请输入查询的班级名称:‘)

class_list=Find(class_name)if len(class_list) ==0:print(‘没有查询到该班级信息。‘)else:for line inclass_list:print(line, end=‘‘)elif (operation == ‘2‘):

dic= input(‘请输入修改的字典数据:‘)

Update(dic)elif (operation == ‘3‘):

dic= input(‘请输入添加的字典数据:‘)

Add(dic)elif (operation == ‘4‘):

class_name= input(‘请输入删除的班级名称:‘)

Delete(class_name)else:print("输入不正确")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/559704.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

摸底谷歌Gemini:CMU全面测评,Gemini Pro不敌GPT 3.5 Turbo

谷歌的 Gemini 到底几斤几两?和 OpenAI 的 GPT 模型相比表现如何?CMU 这篇论文测明白了。 前段时间,谷歌发布了对标 OpenAI GPT 模型的竞品 ——Gemini。这个大模型共有三个版本 ——Ultra(能力最强)、Pro 和 Nano。研…

python3 collections模块 tree_第30天: Python collections 模块

by 豆豆1.简介collections 是 python 的内置模块,提供了很多方便且高性能的关于集合的操作,掌握这些知识有助于提高代码的性能和可读性。2.常用功能2.1 namedtuple 功能详解namedtuple() 返回一个新的元组子类,且规定了元组的元素的个数&…

ddns 被解析为127.0.0.1_我为北京冬奥加油,2020.2.1-2.10冬奥知识分享

2020.02.01中国冬梦,世界飞跃,我是果雪儿小小志愿者仇懿琛,我为北京冬奥加油,今天冬奥知识分享——冬奥会历史上那些非凡而又卓越的运动员(十一)明星运动员:米特迈尔第十二届冬季奥运会时间:1976.02.04-02.…

乱码 转ios_王者荣耀:转区数量提升25倍,教你解决检测异常,IOS也有艾琳了

王者峡谷近期最火的一个功能便是转区服务开放限量测试,由于申请的人数非常多,官方决定从今日起将测试资格由最初的2000个提升至每日开放50000个,同时由每日二次开放调整为每日一次,虽说测试资格数量提升了25倍,但依旧有…

冰豹lua驱动设置_卡宴?卡宴!——冰豹ROCCAT Kain 120 AIMO开箱

前言原本一直在用罗技的G700s,但是鉴于众所周知的“电老虎”原因,再加上重量的问题,一直想换一个鼠标试试,虽然不太玩游戏,但是平时使用也喜欢高DPI的设置、另外还稍许有点汗手的问题,所以对鼠标长时间时候…

vue内检测是否有swiper_vue.js怎么用swiper

vue.js中使用swiper的方法:首先下载【swiper.js】;然后在【main.js】中全局引入【swiper.js】;最后在模板中配置相关内容即可。【相关文章推荐:vue.js】vue.js中使用swiper的方法:1、下载swiper.jsnpm install vue-awe…

mysql创建个自增id的表_MySQL数据库--怎样创建一张用户表,ID设置为自动增长列(新手必会)...

-- phpMyAdmin SQL Dump-- version 3.3.8.1-- http://www.phpmyadmin.net---- 主机: w.rdc.sae.sina.com.cn:3307-- 生成日期: 2011 年 08 月 19 日 16:18-- 服务器版本: 5.1.47-- PHP 版本: 5.2.9---- 数据库: app_tushow---- ----------------------------------------------…

从sqlite 迁移 mysql_将 Ghost 从 SQLite3 数据库迁移到 MySQL 数据库

下面我们就来说说如何从 SQLite 迁移到 MySQL 。准备首先你要已经安装好 MySQL 数据库。如果你用的是 Ubuntu 系统,请参考这篇文章。其他系统请参考各自对应的文档。导出当前数据点击蓝色的 EXPORT 按钮将当前数据库中的所有数据导出并下载到本地,默认文…

易语言mysql验证_易语言MySql注册登录

用到的主要易语言命令:连接MySql (, , , , )执行SQL语句 (, )取记录集 ()读字段值 (, , )释放记录集 ()断开MySql ()命令介绍:①、连接MySql (, , , , ):顾名思义,这条命令是用来连接你的MySql数据库的,返回一个MySql句…

mysql 数据库设置mysql注入_MYSQL数据库浅析MySQL的注入安全问题

《MYSQL数据库浅析MySQL的注入安全问题》要点:本文介绍了MYSQL数据库浅析MySQL的注入安全问题,希望对您有用。如果有疑问,可以联系我们。如果把用户输入到一个网页,将其插入到MySQL数据库,有机会离开了发生安全问题被称为SQL注入敞开.这一课将…

php链接mysql编码错误_php 操作 mysql 数据库 编码 错误

有两行相同的代码,来自不同的 php 文件,在对 MySql 数据库(UTF-8格式)操作时,一行代码正常,一行代码异常代码1,异常update ordersystem.product Set PName333汽车 Where BianhaoX…

mysql 数据记录导出_mysql如何导出600万条记录的数据表?

目前我这么写:/*** Created by IntelliJ IDEA.* User: felix* Date: 2019-03-01* Time: 18:49*/set_time_limit(0);$servername localhost;$username ;$password ;$dbname ;$i 57007;$bingTime microtime(true);echo bing . $bingTime . s . PHP_EOL;while …

mysql sql使用序列_SQL 使用序列

SQL 使用序列序列是根据需要产生的一组有序整数:1, 2, 3 ... 序列在数据库中经常用到,因为许多应用要求数据表中的的每一行都有一个唯一的值,序列为此提供了一种简单的方法。本节阐述在 MySQL 中如何使用序列。使用 AUTO_INCREMENT 列&#x…

jmeter mysql查询结果提取_Jmeter-从数据库中获取数据并作为变量使用

一、导入数据库驱动包;(1)、在网上搜索下载数据库驱动包(MySQL的地址https://dev.mysql.com/downloads/file/?id480090)(2)、解压,获取到jar包,并将其复制到Jmeter的安装路径下的\lib文件夹下面;重启Jmeter就已经成功导入了&…

java 如何跟多个字符串比较_Stack Overflow上370万浏览量的一个问题:如何比较Java的字符串...

在逛 Stack Overflow 的时候,发现了一些访问量像喜马拉雅山一样高的问题,比如说这个:如何比较 Java 的字符串?访问量足足有 370万,这不得了啊!说明有很多很多的程序员被这个问题困扰过。截止到目前为止&…

个人对于MySQL的理解_MySQL锁的理解

一、事务四要素:ACID原子性(Atomicity):要么做完,要么啥都不做,没有中间状态一致性(Consistency):这个是个比较有争议的概念,个人理解是通过AID来保证数据正确性,保证从一个状态到下一个状态是正…

linux mysql 5.6.23_mysql 5.6.23 的安装

安装mysql5.6.231. 先安装cmakeyum -y install gcc gcc-ctar zxvf /home/aa/cmake-3.1.3.tar.gz -C /usr/src/cd /usr/src/cmake-3.1.3/./configuremake && make install2. 安装mysql 5.6.23useradd -M -s /sbin/nologin mysqlyum -y install ncurses ncurses-devel bi…

thinkphp mysql exp_thinkphp备份数据库的方法分享

貌似THINKPHP没有备份数据库的方法,所以我自己写了一个,数据库连接和事务处理用的是pdo,如果有需要的可以联系我,写个mysql或者mysqli的class SqlAction extends Action{function outsql(){header(“Content-Type:text/html;chars…

mysql+distinct+max_MySQL中distinct与group by之间的性能进行比较

最近在网上看到了一些测试,感觉不是很准确,今天亲自测试了一番。得出了结论,测试过程在个人计算机上,可能不够全面,仅供参考。测试过程:准备一张测试表CREATE TABLE test_test (id int(11) NOT NULL auto_i…

增大mysql修改表空间_innodb系统表空间维护方法

环境说明:有一个在运行中的mysql环境,由于之前的配置文件设置的过于简单(没有配置innodb_data_file_path变更);造成现在系统表空间已经满了如果innodb_data_file_path之前没有设置那么它会采用默认值:innodb_data_file_pathibdata1:12M&#…