背景:使用CTS框架运行完测试后,会在logs中生成devices_log和host_log,在results中生成相应的结果(报告)。根据报告信息我们可以得知失败的用例,但是却不能知道为什么用例会失败,是脚本有问题?设备有问题?还是其他.....。此时我们就得通过 截图、视频、log等信息进行分析。然而事实却是很痛苦的,打开log一看密密麻麻的,整个module的日志都在这里面。我就看失败的那条日志,难道还要我选中一段,然后Ctrl+C、Ctrl+V吗?那条用例的log有上千行啊!mmp(通过关键字查找虽然能找到失败的那条,想再进行过滤的话,总是会被其他日志干扰)

问题:我怎样才能拿到我想要的那段log呢?

思路:从log看到会有“TestRunner:started:” 和“TestRunner: finished:”字符串,也就是用例的开始和结束。只要拿到开始和结束的行数就行了。

解决:输入行数提取文本内容。

No1:输入需要截取文本内容的开始和结束行即可。

@echo off &setlocal enabledelayedexpansion
title ExtractContent
color 0a
rem ++++++++++++++++++++++++++++++++++++++++
rem Extract.bat
rem By zhzw @2018/1/18
rem
rem Version: 1.0
rem ++++++++++++++++++++++++++++++++++++++++
echo 1.Can't handle empty lines
:next
echo.
echo 请输入开始行和结束行^>^>^>
set /p sRow=StartRow:
set /p eRow=EndRow: set stime=%time:~0,2%%time:~3,2%%time:~6,2%%time:~9,2%
if "%stime:~0,1%"==" " set "stime=0%stime:~1%"
set /a sRow=%sRow%-1
if "%sRow%"=="0" (set sRow=) else set sRow=skip=%sRow% set start=%sRow:~5%
set stop=%eRow%
if "%stop%"=="" echo."EndRow" cant be equal to null &goto done for /f "%sRow% tokens=* delims=" %%a in (device_logcat.txt) do (
rem echo %sRow%
set /a start+=1
echo %stop%----!start!
echo.%%a >>%stime%.txt
if "%stop%"=="!start!" goto end
)
:end
echo done
set etime=%time:~0,2%%time:~3,2%%time:~6,2%%time:~9,2%
if "%etime:~0,1%"==" " set "etime=0%time:~1%"
echo 开始时间:%stime%
echo 结束时间:%etime%
rem timeout /t 2 &exit
:done
ping 127.0.0.1 -n 3 >nul 2>nul &echo.
echo 终止提取Ctrl+C;继续提取,请按任意键继续...&pause >nul
cls &echo.Try again extract...&goto next

上面的方法不能处理空行(默认不会把空行算为一行),如果文本中出现空行则会导致与所需要的文本内容行数有相差。速度快(貌似是个完美主义者!~_~)

No2:处理了空行的问题。如果行数过大且文本超过MB,读取速度慢,而且行数相差大。(读取整个文本>忽略开始行数-1>截取分隔>写入文本)

@echo off
title ExtractContent
color 0a
rem @mode con lines=35 cols=75
rem ++++++++++++++++++++++++++++++++++++++++
rem Extract.bat
rem By zhzw @2018/1/18
rem
rem Version: 1.0.1
rem ++++++++++++++++++++++++++++++++++++++++
echo 1."StartRow" and "EndRow" cant be equal to null
echo.
set /p sRow=StartRow:
set /p eRow=EndRow: set stime=%time:~0,2%%time:~3,2%%time:~6,2%
if "%stime:~0,1%"==" " set "stime=0%stime:~1%"
set /a sRow=%sRow%-1
if "%sRow%"=="0" (set sRow=) else set sRow=skip=%sRow% for /f "%sRow% tokens=1,* delims=:" %%a in ('findstr /n ".*" device_logcat.txt') do (
rem echo %sRow%
echo %eRow%----%%a
echo.%%b >>%stime%.txt
if %eRow%==%%a goto end
)
:end
echo.
echo done
set etime=%time:~0,2%%time:~3,2%%time:~6,2%
if "%etime:~0,1%"==" " set "etime=0%time:~1%"
echo 开始时间:%stime%
echo 结束时间:%etime%
rem timeout /t 2 &exit
pause

No3:弥补数据准确性的问题,大行数时速度慢[No1>No3>No2]。(以行号查找文本中指定行>写入文本)

@echo off &setlocal enabledelayedexpansion
title ExtractContent
color 0a
rem ++++++++++++++++++++++++++++++++++++++++
rem Extract.bat
rem By zhzw @2018/1/18
rem
rem Version: 1.0.2
rem ++++++++++++++++++++++++++++++++++++++++
echo 1."StartRow" and "EndRow" cant be equal to null
echo.
set /p sRow=StartRow:
set /p eRow=EndRow: set stime=%time:~0,2%%time:~3,2%%time:~6,2%
if "%stime:~0,1%"==" " set "stime=0%stime:~1%" set start=%sRow%
set /a stop=%eRow%+1
echo.
:replay
rem echo %start%
for /f "tokens=1,* delims=:" %%a in ('findstr /n ".*" device_logcat.txt ^| findstr /b "\<%start%:"') do (
set /a start+=1
echo %stop%----!start!
if "%stop%"=="!start!" goto end
echo.%%b >>%stime%.txt &goto replay
)
:end
echo.&echo done
set etime=%time:~0,2%%time:~3,2%%time:~6,2%
if "%etime:~0,1%"==" " set "etime=0%etime:~1%"
echo 开始时间:%stime%
echo 结束时间:%etime%
rem timeout /t 2 &exit
pause

去除空行处理:

type a.txt | findstr /v "^$"

  

bat如何提取文本指定行的内容的更多相关文章

  1. css3实现超出文本指定行数(指定文本长度)用省略号代替

    测试代码: <!DOCTYPE html> <html> <head> <meta name="viewport" content=&qu ...

  2. Linux查看文件指定行数内容

    1.tail date.log               输出文件末尾的内容,默认10行 tail -20  date.log        输出最后20行的内容 tail -n -20  date ...

  3. 【Sed】使用sed删除文件指定行的内容

    sed多看帮助文档,受益良多 sed -i '$d' filename 例如删除 /etc/profile的最后一行 cat -n /etc/profile ...    101  export PA ...

  4. Linux 显示文本指定行内容

    主要采用sed.head和tail命令 如果文本中使用了 \n 这类符号,cat命令会把它当成换行符,结果会出错 $ sed -n "10p" move.sh   # 显示第10行 ...

  5. Shell 获取指定行的内容

    需求: 有一个文件,根据指定的字符串,得到该字符串上两行的内容. 文件内容如下: linux-56:# cat sys.ttconnect.ini # Copyright (C) 1999, 2006 ...

  6. php替换文件指定行的内容

    //第一种 利用file 函数 读取文件,每一行都是一个数组元素 $arr = file($file); $arr[$line] = "hello"; file_put_conte ...

  7. linux在文件中包含某个关键词的指定行插入内容

    1. 在包含某个关键字的行上面插入一行文字 sed -i '/wangzai/i\doubi' 1.txt 把内容doubi插入到包含wangzai关键字的上一行 2. 在包含某个关键字的行下面插入一 ...

  8. linux 向文本指定位置写入内容

    sed -i "37 r a.txt" test.txt ====== 向test.txt 的第37行后,也就是38行后写入a.txt的内容 sed -i "38i aa ...

  9. 利用css3实现超出文本指定行数与省略号效果

    <style> .text1 {/*单行*/ width:200px; overflow:hidden; text-overflow:ellipsis; -o-text-overflow: ...

随机推荐

  1. [C++]PAT乙级1005. 继续(3n+1)猜想 (25/25)

    /* 1005. 继续(3n+1)猜想 (25) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推 ...

  2. django drf 基础学习1

    一 环境配置    python3.5+ django2.0 pymysql二 安装   /usr/bin/python3 -m pip install django   /usr/bin/pytho ...

  3. SpringMVC中JSONP的基本使用

    @RequestMapping("/check/{param}/{type}") @ResponseBody public Object checkData(@PathVariab ...

  4. sonar的安装以及使用

    SonarQube是管理代码质量一个开放平台,可以快速的定位代码中潜在的或者明显的错误,下面将会介绍一下这个工具的安装.配置以及使用. 1. 简介 1.  sonar是什么 Sonar是一个用于代码质 ...

  5. dubbo学习笔记1

    DUBBO入门 官方文档:https://dubbo.gitbooks.io/dubbo-user-book/content/preface/ 服务提供者 项目结构: pom文件: <?xml ...

  6. 论文笔记:Batch Normalization

    在神经网络的训练过程中,总会遇到一个很蛋疼的问题:梯度消失/爆炸.关于这个问题的根源,我在上一篇文章的读书笔记里也稍微提了一下.原因之一在于我们的输入数据(网络中任意层的输入)分布在激活函数收敛的区域 ...

  7. CVE-2019-0797漏洞:Windows操作系统中的新零日在攻击中被利用

    https://securelist.com/cve-2019-0797-zero-day-vulnerability/89885/ 前言 在2019年2月,卡巴实验室的自动漏洞防护(AEP)系统检测 ...

  8. js知识巩固

    1.数组操作中使用splice和slice进行删除数组的区别! splice会对原数组进行操作,返回的是被删除元素组成的数组,原数组会被进行改变即变成删除后的数组,用于删除列表中的元素,arr.spl ...

  9. 带你十分钟快速构建好 SpringBoot + SSM 框架

    目前最主流的 java web 框架应该是 SSM,而 SSM 框架由于更轻便与灵活目前受到了许多人的青睐.而 SpringBoot 的轻量化,简化项目配置, 没有 XML 配置要求等优点现在也得到了 ...

  10. 微信小程序-聊天列表-角标

    <div class="list-body" bindtap='openChat' data-Obj='{{oitem}}'> <!-- 头像 --> &l ...