首页 > 数据库 >Python|文件处理与数据库编程

Python|文件处理与数据库编程

时间:2022-12-22 19:11:26浏览次数:55  
标签:__ 文件 cur Python 数据库 编程 write sql print

某农带专业Python课实验三

txt文件处理

题目描述:编程新建一个名为test.txt文件,存放在代码文件所在目录中,并且打开该文件。然后写入如图1-1所示内容到文件中。最后分别读取5个字符、读取第一行字符串、读取第三行的字符串,读取所有字符串。如图1-2所示。

提示:使用文件操作函数open()、write()、read()、readline()、readlines()、seek()、tell()、close()。

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: operate_txt 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""

if __name__ == "__main__":
   # 创建并打开文件
   f = open("tjl.txt", "w+")

   # 写入内容
   for i in range(5):
      f.write("chriswpf" + str(i + 1) + "\n")
   f.close()

   # 读取文件
   f = open("tjl.txt", "r")
   print("读5个字符是:" + f.read(5))

   f.seek(0)
   print("读第一行字符串是:" + f.readline(), end='')

   f.seek(f.tell() * 2)
   print("读第三行字符串是:" + f.readline())

   f.seek(0)
   print("读所有行字符串是:")
   fs = f.readlines()
   for line in fs:
      print(line[:-1], end=' ')
   f.close()

csv文件处理

题目描述:编程新建一个名为test.csv文件,存放在代码文件所在目录中,并且打开该文件。然后写入如图2-1所示内容到文件中。最后读取所有文件数据,如图2-2所示。

提示:import csv # csv是内建模块,直接使用

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: operate_csv 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""

import csv

if __name__ == '__main__':
   # 写入文件
   numlist = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
   f = open("tjl.csv", "w+", newline="")
   csvwriter = csv.writer(f)
   for item in numlist:
      csvwriter.writerow(item)
   f.close()
   f = open("tjl.csv", "r", newline="")
   csvreader = csv.reader(f)
   for row in csvreader:
      print(row)
   f.close()

excel文件处理

题目描述:编程新建一个名为test.xls文件,存放在代码文件所在目录中,并且打开该文件。然后通过xlwt模块写入如图3-1所示内容到文件中。最后通过xlrd模块读取所有文件数据,如图3-2所示。

提示:安装xlrd读模块,安装xlwt写模块。

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: operate_excel 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""
import xlrd
import xlwt
if __name__ == '__main__':
   book = xlwt.Workbook(encoding="utf-8")
   sheet = book.add_sheet("student" , cell_overwrite_ok=True)
   sheet.write(0, 0, '学号')
   sheet.write(0, 1, '姓名')
   sheet.write(0, 2, '性别')
   sheet.write(0, 3, '年龄')
   sheet.write(0, 4, '班级')
   sid = ['2018001', '2018001', '2018001', '2018001', '2018001']
   sname = ['张珊', '李斯', '王武', '赵柳', '吴鹏飞']
   ssex = ['女', '男', '男', '女', '男']
   sage = [18, 19, 18, 19, 18]
   sclass = ['计算机1801', '计算机1802', '计算机1801', '计算机1802', '计算机1801']
   for i in range(len(sid)):
      sheet.write(i + 1, 0, sid[i])
      sheet.write(i + 1, 1, sname[i])
      sheet.write(i + 1, 2, ssex[i])
      sheet.write(i + 1, 3, sage[i])
      sheet.write(i + 1, 4, sclass[i])
   book.save("test.xls")

   wb = xlrd.open_workbook("test.xls")
   sheet1 = wb[0]
   print(sheet1.name + "信息如下: ")
   for i in range(sheet1.nrows):
      print(sheet1.row(i)[0].value, end=" ")
      print(sheet1.row(i)[1].value, end=" ")
      print(sheet1.row(i)[2].value, end=" ")
      print(sheet1.row(i)[3].value, end=" ")
      print(sheet1.row(i)[4].value, end=" ")
      print()

word文件处理

题目描述:编程新建一个名为test.doc文件,存放在代码文件所在目录中,并且打开该文件。然后写入如图4-1所示内容到文件中。最后分别读取5个字符、读取第一行字符串、读取第三行的字符串,读取所有字符串。如图4-2所示。

提示:使用文件操作函数open()、write()、read()、readline()、readlines()、seek()、tell()、close()。

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: operate_word 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""

if __name__ == '__main__':
   # 创建并打开文件
   f = open("test.doc", "w+", encoding="utf-8")

   # 写入内容
   for i in range(1, 6):
      f.write("华中农业大学" + str(i) + "\n")
   f.close()

   # 读取文件
   f = open("test.doc", "r", encoding="utf-8")  # r:读模式

   print("读6个文字是:" + f.read(6))

   f.seek(0)
   print("读第一行文字是:" + f.readline(), end='')
   f.seek(f.tell() * 2)  # 定位到第2号行位置
   print(f.tell())
   print("读第三行文字是:" + f.readline())

   f.seek(0)
   print("读所有行文字是:")
   fs = f.readlines()
   for line in fs:
      print(line[:-1], end=' ')

   f.close()  # 关闭文件

sqlite3数据库编程

题目描述:创建一个测试数据库test. db,该数据库中包含一张student表,该数据表含有五个字段学号sid、姓名sname、性别ssex、年龄sage、班级sclass。

提示

通过SQL语句insert、delete、update、select分别实现对应数据操作功能。

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: py_SQLite 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""

import sqlite3

if __name__ == '__main__':
	conn = sqlite3.connect("test.db")
	cur = conn.cursor()

	create_sql = """create table student
		    (sid char(2) primary key not null,
		    sname char(4) not null,
		    ssex char(6) not null,
		    age char(6) not null,
		    class char(20) not null
		    )
		    ;"""
	cur.execute(create_sql)

	# 添加一条数据记录
	addsql1 = "insert into student values('2018005','王2','男',18,'计算机1803')"
	add_sql = "insert into student values('2018004','王1','男',19,'计算机1803')"
	cur.execute(add_sql)
	cur.execute(addsql1)
	conn.commit()

	# 删除一个数据记录
	del_sql = "delete from student where sid='2018004'"
	cur.execute(del_sql)
	conn.commit()

	# 修改一个数据记录
	update_sql = "update student set sname='赵柳', ssex='女' where sid='2018005';"
	cur.execute(update_sql)
	conn.commit()

	# 查询所有数据记录
	all_sql = 'select * from student'
	cur.execute(all_sql)
	ds = cur.fetchall()
	for row in ds:
		print(row)

	cur.close()
	conn.close()

mysql数据库编程

题目描述:创建一个测试数据库test.db,该数据库中包含一张teacher表,该数据表含有六个字段教工号tid、姓名tname、性别tsex、年龄tage、职称ttitle。

提示

通过SQL语句insert、delete、update、select分别实现对应数据操作功能。

# -*- coding: utf-8 -*-
"""
PROJECT_NAME: pythonProject_ lesson 
FILE_NAME: py_mySQL 
AUTHOR: welt 
E_MAIL: tjlwelt@foxmail.com
DATE: 2022/12/1 
"""

import pymysql
if __name__ == '__main__':
   conn = pymysql.connect("localhost", "root", "tjl20021006", "tjl", charset="utf8")
   cur = conn.cursor()

   # 添加一条数据记录
   sql="insert into teacher values('2018005','王1','男',32,'讲师','理学院')"
   cur.execute(sql)
   conn.commit()

   # 删除一个数据记录
   sql = "delete from teacher where tid='2018005'"
   cur.execute(sql)
   conn.commit()

   # 修改一个数据记录
   sql="update teacher set tname='wpf', ttitle='副教授' where tid='2018005'"
   cur.execute(sql)
   conn.commit()

   # 查询所有数据记录
   sql = "select * from teacher;"
   cur.execute(sql)
   ds = cur.fetchall()
   for row in ds:
      print(row)

   cur.close()
   conn.close()

标签:__,文件,cur,Python,数据库,编程,write,sql,print
From: https://www.cnblogs.com/tangjielin/p/16999420.html

相关文章

  • 《Unix编程艺术》
    1. 不懂Unix的人注定最终还要重复发明一个蹩脚的Unix。2. 以太网的发明者曾经说过:如果将来有什么技术来取代以太网,那么这个取代物的名字还会叫“以太网”,因为以太网是永远......
  • 从全球顶级数据库大会 SIGMOD 看数据库发展趋势
    本文来自NebulaGraph的软件工程师文豪在美国费城参加2022年SIGMOD大会时的见闻。SIGMOD是数据库领域的顶级会议之一,是CCF数据库/数据挖掘/内容检索领域A类......
  • Java编程思想4
    第九章:接口接口也可以包含域,但是这些域隐式地是static和final的(因此接口就成为了一种很便捷的用来创建常量组的工具)。你可以选择在接口中显示地将方法声明为public的,但即使......
  • 【Python】羊毛获取小工具
    前言最近沉迷薅羊毛,然后想第一时间得到新的消息。不过说实话第一时间是不存在的,除非跟商家直接对接。于是乎只能靠微博啊,企鹅群等,看别人发的新信息了。那么做一个简单......
  • python mac docx格式转pdf
    1.翻了很多资料发现大多是Windows的库偏多,并且不支持linux,还需要借助word软件,方案是首先docx转html再转pdf代码:frompydocximportPyDocXfromxhtml2pdfimportp......
  • 【python爬虫课程设计】2022-23赛季欧洲冠军联赛——绘制球员数据柱状图和词云
    一、选题的背景1.背景:2022-23赛季欧洲冠军联赛(2022–23UEFAChampionsLeague)由欧洲足球联合会主办的第68届欧洲足球俱乐部的顶级赛事,也是以欧洲冠军联赛名义下的第31届......
  • python爬虫-美团海底捞评论及评分数据爬取和分析
    美团海底捞评论及评分数据爬取和分析一、选题背景  通过网络请求的方式获取响应数据,再对获取的数据进行分析提取和汇总,并储存到xlsx表格中。在进入互联网存储海量数据......
  • centos安装python3
    1:使用CentOS自带的包管理器yum安装新版本的Python。例如,你可以使用以下命令安装最新的Python3版本:sudoyumupdatesudoyuminstallpython32:使用SCL库安......
  • python 数组字典转换
    将提交的数组字段一个字典 [ { "name":"name1", "age":"1", }, { "name":"name2", "age":"2", } ]#变成{ "name":"name1,name2",......
  • 实验5 结构体应用编程
    1#define_CRT_SECURE_NO_WARNINGS2#include<stdio.h>3#include<string.h>4#defineN10056typedefstruct{7charnum[10];//学号8......