取出文件中含有指定字段的全部行,并写入另一份文件

在Linux环境下或使用Xshell连接到服务器,用grep命令,将文本或日志中的含有指定字段的全部行取出并写入另一份文本中:
例如,将Home.log中含有aaa字段的全部行取出,并写出到同目录下new.log中:

grep -i "aaa" Home.log > new.log  

说明:
-i 为忽略大小写功能
用"aaa"来指定需要搜索的字段
“>”的右边是抽取出的文本要写入的目标文件

### MATLAB 中将自定义命名的 .mat 文件存为 .xlsx 格式 为了实现这一目标,可以编写一段脚本用于遍历指定目录下的 `.mat` 文件将其内容逐个导出至相应的 Excel 文件中。考虑到不同版本的 `.mat` 文件可能存储复杂的数据结构(如数组、元胞数组或结构体),因此需要适当地解析这些数据以便于后续操作。 对于简单的数值矩阵或多维数组而言,可以直接利用 `writematrix()` 函数来完成转换过程;而对于更复杂的变量,则建议先通过 `importdata()` 或者更为灵活的 `load()` 命令加载数据后再做进一步处理[^2]。 下面给出了一段适用于大多数情况的通用代码: ```matlab clc; clear; % 获取当前文件夹下所有.mat文件的信息 matFiles = dir('*.mat'); for k = 1:length(matFiles) % 加载.mat文件的内容到临时变量tempData中 tempData = load(matFiles(k).name); % 提取.mat文件的基础名称部分作为的.xlsx文件的名字 [~, name, ~] = fileparts(matFiles(k).name); excelFileName = sprintf('%s.xlsx', name); % 遍历加载后的结构体字段将它们逐一写入Excel表单内 structFields = fieldnames(tempData); for i = 1:numel(structFields) fieldName = structFields{i}; % 如果该字段对应的是一个普通的二维数组则直接写出, % 否则尝试转化为cell形式再输出 dataToWrite = getfield(tempData, fieldName); if isnumeric(dataToWrite) && ndims(dataToWrite)==2 sheetName = fieldName; %#ok<NASGU> writetable(array2table(dataToWrite), ... 'Filename', excelFileName,... 'Sheet',sheetName); else cellData = num2cell(dataToWrite(:)); sheetName = [fieldName '_converted']; T = array2table(cellData'); writetable(T, ... 'Filename', excelFileName,... 'Sheet',sheetName); end end end ``` 这段程序首先清除了工作空间内的旧变量以防止干扰任务执。接着获取了当前路径下所有的 `.mat` 文件列表,循环访问其中每一项。针对每一份被选中的 `.mat` 文件,使用 `load()` 方法读取出其内部所含有全部变量形成一个的结构体实例 `tempData` 。随后依据原文件名创建了一个同名但扩展名为 `.xlsx` 的电子表格文档准备接收即将转化而来的资料。最后一步则是迭代遍历这个刚得到的结构体内各个成员——即原始 `.mat` 文件里的独立对象们——分别调用适当的方式把它们记录下来。 值得注意的是,在实际应用过程中应当根据具体需求调整上述逻辑细节,比如当面对特定类型的非标准输入时就需要额外增加预处理环节确保最终结果的一致性和可用性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值