栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

武汉光迅科技22校招笔试题(武汉邮科院控股国企上市大厂Python的txt文本处理笔试题)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

武汉光迅科技22校招笔试题(武汉邮科院控股国企上市大厂Python的txt文本处理笔试题)

武汉光迅科技22校招笔试题(武汉邮科院控股国企上市大厂Python的txt文本处理笔试题)

资源:
https://download.csdn.net/download/weixin_53403301/33844279

题目要求:

  1. 输入数据: 见附件 <125模块温度查询数据.txt>

    #号开头的是命令, #号的下一行是命令应答内容

  2. 输出结果:提取指定字段的值,输出到文件 <125温度统计.txt>
    即上图中01 f1 字段,对应每条应答消息的倒数第5和第4个字节。
    497
    497
    497
    497

  3. 根据 步骤2的结果数据,并用Python 输出图谱

这里只用到了一个库 就是matplotlib 用于绘制最后的坐标图

Python 3.7.0 (default, Jun 28 2018, 08:04:48) [MSC v.1912 64 bit (AMD64)] :: Anaconda, Inc. on win32 matplotlib.version == 2.2.3

思路:
先将#所在行删除
再删除空白行
然后匹配到每一行的第11和12个字符 做16进制整型转10进制的转换
最后将结果按x y坐标对应关系绘制坐标图

直接上代码:

# -*- coding: utf-8 -*-
"""
Created on Fri Oct 22 17:44:48 2021

@author: 16016
"""
# Python 3.7.0 (default, Jun 28 2018, 08:04:48) [MSC v.1912 64 bit (AMD64)] :: Anaconda, Inc. on win32
# matplotlib.__version__ == 2.2.3

import matplotlib.pyplot as plt # 调用matplotlib绘图库
plt.rcParams['font.sans-serif'] = ['SimHei'] # 载入字体
import os # 调用系统控制库


def removeCharterLine(path1, path2): # 读取温度文档文件 去除#符号 并保存在临时文件中
    f = open(path1, 'r')
    f2 = open(path2, 'w')

    for i in f:
        if not i.strip().startswith("#"):
            f2.write(i)

    f.close()
    f2.close()

def removeBlock(path1,path2): # 读取第一个临时文件 去除空行 并保存在临时文件2中
    with open(path1,'r',encoding = 'utf-8') as fr,open(path2,'w',encoding = 'utf-8') as fd:
        for text in fr.readlines():
            if text.split():
                fd.write(text)
                fr.close
                fd.close
                        
def transData(path1,path2,path3): # 读取 临时文件2 输出温度文档文件和临时文件3
    # 将临时文件2中的每一行的数据用空格分开 提取第11和12个数据 并将其由字符串类型转为16进制整型 再转换为10进制
    # 将十进制数据保存在输出温度文档文件中
    # 将输出温度文档中的数据每一行前面都加上序号 代表第x个数据 保存在临时文件3中 并返回数据总数+1
    file1 = open(path1,'r')
    file2 = open(path2,'w')
    file3 = open(path3,'w')
    count = int()
    count = 1
    for line in file1.readlines():
        curLine=line.strip().split(" ")    
        hexData=curLine[11]+curLine[12]
        decData=int(hexData,16)
        strData=str(decData)
        file2.write(strData+"n")
        file3.write(str(count)+' '+strData[0]+strData[1]+'.'+strData[2]+"n")
        count=count+1
    file1.close
    file2.close
    file3.close
    return count

def drawData(path1,i,minTemp,maxTemp): # 读取临时文件3 将每一行用空格分开 xy坐标值对应第0、1数据
    # 输入参数i表示数据总数(x轴)+1的值
    # 输出参数minTemp和maxTemp表示最低、最高温度范围 用于调整y轴比例
    input_txt = path1
    x = []
    y = []
    
    f = open(input_txt,'r')
    
    for line in f:
        line = line.strip('n')
        line = line.split(' ')
    
        x.append(float(line[0]))
        y.append(float(line[1]))
    
    f.close
    j=int(i/4//100*100)
    k=float((maxTemp-minTemp)/5)
    plt.plot(x, y, '-',marker=',', markersize = '1')
    plt.xticks([0,j,j*2,j*3,j*4,i])
    plt.yticks([minTemp,minTemp+k,minTemp+2*k,minTemp+3*k,minTemp+4*k,maxTemp])
    plt.xlabel('x')
    plt.ylabel("temp")
    plt.title("temp")
    plt.tick_params(axis="both")
    plt.show()                        

def addData(path1,i): #可省略 增加第一行的 0 0数据 和最后一行的2155 100数据
    
    fp = open(path1)           #指定文件
    s = fp.read()                   #将指定文件读入内存
    fp.close()                      #关闭该文件
    a = s.split('n')
    a.insert(0, '0 0')    #在第 0行插入
    s = 'n'.join(a)                #用'n'连接各个元素
    fp = open(path1, 'w')
    fp.write(s)
    fp.close()
    
    f=open(path1,"a")
    f.write(str(i)+' 100') # 将温度值100及其序号写入最后一行
    f.close()
    
if __name__ == '__main__':  
    filepath1='./125模块温度查询数据.txt'
    filepath2='./125温度统计.txt'
    tempfile1='./new1.txt'
    tempfile2='./new2.txt'
    tempfile3='./new3.txt'
    removeCharterLine(filepath1,tempfile1)          # 删除#符号             
    removeBlock(tempfile1,tempfile2)                # 删除空行
    Count=transData(tempfile2,filepath2,tempfile3)  # 输出温度数据 给数据增加序号并输出临时文件 获取数据总数+1的值
#    addData(tempfile3,Count) #可省略 增加第一行的 0 0数据 和最后一行的2155 100数据
    drawData(tempfile3,Count,0,100) # 画坐标图 输入读取文件 数据总数+1的值 和 最低、最高温度值
    # 删除临时文档文件
    os.remove(tempfile1)
    os.remove(tempfile2)
    os.remove(tempfile3)

最后运行结果如下:

输入文件:125模块温度查询数据.txt

输出文件:125温度统计.txt


三个临时创建的txt文件:new.txt new2.txt new3.txt

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/348808.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号