专栏首页python 自动化测试python处理txt文件常用方法

python处理txt文件常用方法

分享切割txt文件、合并txt文件、excel转txt方法
"""
 * Create by dell on 2020/23
 * Author :wencheng
 * 微信公众 :自动化测试 To share

"""
import os
import os.path


def spilt_file():
    limit = 1000000  # 切割后单个文件的最大行数
    file_count = 0
    line_list = []
    # 打开需要切割的文件
    with open(r'testlog.txt', 'r', errors='ignore') as f:
        for line in f:  # 读取每一行
            line_list.append(line)  # 把每一行数据分别加入到line_list列表里面
            if len(line_list) < limit:  # 如果line_list列表的长度‘小’于指定的切割后单个文件的最大行数
                continue
            file_name = './data/log' + str(file_count) + '.txt'  # 如果line_list列表的长度‘等’于指定的切割后单个文件的最大行数
            with open(file_name, 'w') as file:  # 写入文件
                for new_line in line_list[:-1]:
                    file.write(new_line)
                file.write(line_list[-1].strip())
                line_list = []
                file_count += 1
    if line_list:  # 文件读取完后,如果line_list列表里仍有数据未保存,就把数据写入一个文件
        file_name = './data/log' + str(file_count) + '.txt'
        with open(file_name, 'w') as file:
            for line in line_list:
                file.write(line)

    print('done')


def MergeTxt(filepath, outfile):
    k = open(filepath + outfile, 'a+')
    for parent, dirnames, filenames in os.walk(filepath):
        for filepath in filenames:
            txtPath = os.path.join(parent, filepath)  # txtpath就是所有文件夹的路径
            f = open(txtPath)
            ##########换行写入##################
            # k.write(f.read()+"\n")
            k.write(f.read())
    k.close()
    print("finished")


import xlwt  # 需要的模块


def txt_xls(filename, xlsname):
    """
    :文本转换成xls的函数
    :param filename txt文本文件名称、
    :param xlsname 表示转换后的excel文件名
    """
    try:
        f = open(filename, encoding="utf-8")
        xls = xlwt.Workbook()
        # 生成excel的方法,声明excel
        sheet = xls.add_sheet('sheet1', cell_overwrite_ok=True)
        x = 0
        while True:
            # 按行循环,读取文本文件
            line = f.readline()
            if not line:
                break  # 如果没有内容,则退出循环
            for i in range(len(line.split('\t'))):
                item = line.split('\t')[i]
                items = item.split(":")
                print(items[1])
                sheet.write(x, i, items[0])  # x单元格经度,i 单元格纬度
            x += 1  # excel另起一行
        f.close()
        xls.save(xlsname)  # 保存xls文件
    except:
        raise

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家的支持。

本文分享自微信公众号 - 自动化测试 To share(gh_92d7607a3e04),作者:wencheng

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-08-23

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Docker下搭建禅道管理系统

    禅道是第一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管...

    wencheng
  • python常用文本串处理库学习笔记

    以下就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值

    wencheng
  • python的安装

    因为 Python 是跨平台的,它可以运行在 Windows、Mac 和各种 Linux/Unix 系统上。目前,Python 有两个版本,一个是 2.x 版,...

    wencheng
  • 两天研习Python基础(十) 文件处理

    [1]Python文档 - open: https://docs.python.org/3/library/functions.html#open

    王诗翔呀
  • HDU 1017 A Mathematical Curiosity【水,坑】

    A Mathematical Curiosity Time Limit: 2000/1000 MS (Java/Others)    Memory Limit:...

    Angel_Kitty
  • A Mathematical Curiosity hdu1017

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe...

    用户2965768
  • 18.6.17日报

    原因是页面会reload,而mb会把所有env里的uv的handle全部close。导致vscode的sharp process的有名管道的handleye

    龙泉寺扫地僧
  • 获取豆瓣电影TOP 250并存入文件

    tanmx
  • Code Forces 21C Stripe 2

    C. Stripe 2 time limit per test 1 second memory limit per test 64 megabyte...

    ShenduCC
  • codeforces 509B(构造,思维)

    There are n piles of pebbles on the table, the i-th pile contains a i pebbles. Y...

    dejavu1zz

扫码关注云+社区

领取腾讯云代金券