自己的第一个网页

自己的第一个网页

文件读写的读书笔记

文件是一个存储在辅助存储器上的数据序列,可以包含任何数据内容

文件都是按照2进制进行存储的,但在表现形式上有2种:文本文件和二进制文件

1. 文本文件

  文本文件一般由单一特定编码的字符组成,如utf-8编码,内容容易统一展示和阅读,大部分文本文件都可以通过文本编辑软件和文字处理软件创建、修改和阅读,最常见的是txt格式的文本文件。

  文本文件采用文本方式打开时,文件通过编码形成字符串;采用二进制方式打开时,文件被解析成字节流。由于存在编码,字符串中的一个字符由两个字节表示。

2. 二进制文件

  二进制文件直接由比特0和比特1组成,没有统一字符编码。二进制文件其实也是常见的,如png格式的图片文件、avi格式的视频文件等等。

 

文件的使用分为3步:打开文件、读写文件、关闭文件。

1. 打开文件

变量名 = open (文件名打开模式)

r 只读模式 (默认),文件不存在则返回FileNotFoundError异常

w 覆盖写模式,文件不存在则创建,存在则覆盖写

x 创建写模式,文件不存在则创建,存在则返回FileExistsError异常

a 追加写模式,文件不存在则创建,存在则追加写

t 文本文件模式 (默认)

b 二进制文件模式

+ 在原功能基础上增加读写功能

 

 

2. 读文件

 

读文件方法 说明

 

<file>.read(size=-1) 从文件中读入所有内容,若有参数,则读入前size长度的字符串或字节流

 

<file>.readline(size=-1) 从文件中读入一行内容,若有参数,则读入改行前size长度的字符串或字节流

 

<file>.readlines(hint=-1) 从文件中读入所有行,以每行为元素形成列表,若有参数,则读入hint

 

 

3. 写文件

 

写文件方法 说明

 

<file>.write(s) 向文件中写入一个字符串或字节流

 

<file>.writelines(lines) 将一个全为字符串的列表写入文件

 

<file>.seek(offset) 改变当前文件操作指针的位置(offset值)

 

0:文件开头;1:当前位置;2:文件结尾

 

 

4. 关闭文件

 

变量名.close()

 

 

 


读入excel文件,并存为csv格式,并把优秀变成90分,良好80及格60,没有交0分

import pandas as pd
grade = pd.read_excel(r"E:\1.xlsx", sheet_name="Sheet1") # filename为excel表格的文件路径
for i in range(len(grade.index)):
    for j in range(1, len(grade.columns)):
        if grade.iloc[i, j] == '优秀':
            grade.iat[i, j] = 90
        elif grade.iloc[i, j] == '良好':
            grade.iat[i, j] = 80
        elif grade.iloc[i, j] == '合格':
            grade.iat[i, j] = 60
        else:
            grade.iat[i, j] = 0
grade.to_csv("weijian.csv") # csv文件的保存路径

把上述csv格式文件转换为html文件

def fill_data(excel, length=4):
     text = '<tr>'
     for i in range(length):
         tmp = '<td align="center">{}</td>'.format(excel[i+1])
         text += tmp
     text += "</tr>\n"
     return text
 
 def GetCsv(csvFile):
     ls = []
     csv = open(csvFile, 'r', encoding="utf-8")
     for line in csv:
         line = line.replace('\n', '')
         ls.append(line.split(','))
     return ls
 
 
 def CsvToHtml(csvFile, HTMLFILE, thNum):
     HTML1 = '''
 <!DOCTYPE HTML>\n<html>\n<body>\n<meta charset=gbk2313>
 <h1 align=center>weijian</h2>
 <table border='blue'>\n'''
     HTML2 = "</table>\n</body>\n</html>"     
     csv_list = GetCsv(csvFile)      # 获得csv文件数据
     hF = open(HTMLFILE, 'w') # 创建html文件
     hF.write(HTML1)                                             # 写入html文件首部
     for i in range(1, thNum+1):        # 写入表格的表头(即第1行)
         hF.write('<th width="20%">{}</th>\n'.format(csv_list[0][i]))
     hF.write("</tr>\n")
     for i in range(1, len(csv_list)):  # 写入表格的数据,从第2行开始为数据
         hF.write(fill_data(csv_list[i], 5))
     hF.write(HTML2)                                            # 写入html文件尾部
     hF.close()               # 关闭html文件
 
 CsvToHtml("‪D:\python\Python.csv", "‪D:\python\Python.html", 5)

  

 

posted on 2020-06-18 10:28  zhangsijie  阅读(143)  评论(0)    收藏  举报

导航