文件名无规则情况读取

C++读取文件夹内图片
本文介绍了一个使用C++编写的程序,该程序能够从指定文件夹中读取所有图片文件,并利用OpenCV库显示这些图片。此外,文章还提供了一种将宽字符字符串(LPCWSTR)转换为ANSI字符串的方法。
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
#include <stdio.h>
#include <windows.h>
using namespace std;
// LPCWSTR转string
std::string WChar2Ansi(LPCWSTR pwszSrc)
{
	int nLen = WideCharToMultiByte(CP_ACP, 0, pwszSrc, -1, NULL, 0, NULL, NULL);

	if (nLen <= 0) return std::string("");

	char* pszDst = new char[nLen];
	if (NULL == pszDst) return std::string("");

	WideCharToMultiByte(CP_ACP, 0, pwszSrc, -1, pszDst, nLen, NULL, NULL);
	pszDst[nLen - 1] = 0;

	std::string strTemp(pszDst);
	delete[] pszDst;

	return strTemp;
}

// 利用winWIN32_FIND_DATA读取文件下的文件名
void readImgNamefromFile(char* fileName, vector <string> &imgNames)
{
	// vector清零 参数设置
	imgNames.clear();
	WIN32_FIND_DATA file;
	int i = 0;
	char tempFilePath[MAX_PATH + 1];
	char tempFileName[50];
	// 转换输入文件名
	sprintf_s(tempFilePath, "%s/*", fileName);
    // 多字节转换
	WCHAR   wstr[MAX_PATH] = { 0 };
	MultiByteToWideChar(CP_ACP, 0, tempFilePath, -1, wstr, sizeof(wstr));
	// 查找该文件待操作文件的相关属性读取到WIN32_FIND_DATA
	HANDLE handle = FindFirstFile(wstr, &file);
	if (handle != INVALID_HANDLE_VALUE)
	{
		FindNextFile(handle, &file);
		FindNextFile(handle, &file);
		// 循环遍历得到文件夹的所有文件名	
		do
		{
			sprintf(tempFileName, "%s", fileName);
			imgNames.push_back(WChar2Ansi((file.cFileName)));
			imgNames[i].insert(0, tempFileName);
			i++;
		} while (FindNextFile(handle, &file));
	}
	FindClose(handle);
}
int main()
{
	// 设置读入图像序列文件夹的路径
	char* fileName = "..\\images\\test\\";
	std::vector <string>  imgNames;
	// 获取对应文件夹下所有文件名
	readImgNamefromFile(fileName, imgNames);
	// 遍历对应文件夹下所有文件名
	for (int i = 0; i < imgNames.size(); i++)
	{
		cv::Mat img = cv::imread(imgNames[i]);
		if (!img.data)
			return -1;
		/* 可添加图像处理算法code*/
		cv::imshow("im", img);
		cv::waitKey(0);
	}
	return 0;
}

转载:http://blog.youkuaiyun.com/zhuwei1988

以下是改进后的Python脚本,可以处理文件夹中**所有**Excel文件(无需预先知道文件名),并读取指定的单元格位置(可针对不同sheet): ```python import os from openpyxl import Workbook, load_workbook def batch_read_unknown_excel(input_folder, output_file, target_cells): """ :param input_folder: 存放Excel文件的文件夹路径 :param output_file: 输出汇总表的文件路径 :param target_cells: 列表格式 [(sheet名, 单元格坐标, 输出列名)] 例: [("Sheet1", "A1", "姓名"), ("Sheet2", "B3", "金额")] """ # 创建输出工作簿 output_wb = Workbook() output_ws = output_wb.active output_ws.title = "汇总数据" # 动态生成表头 headers = ["文件名"] + [col for _, _, col in target_cells] output_ws.append(headers) # 遍历文件夹中的所有Excel文件 for filename in os.listdir(input_folder): if filename.lower().endswith(('.xlsx', '.xls')): filepath = os.path.join(input_folder, filename) try: wb = load_workbook(filepath, data_only=True) row_data = [filename] # 第一列总是文件名 for sheet_name, cell_ref, _ in target_cells: try: ws = wb[sheet_name] value = ws[cell_ref].value row_data.append(value) except Exception as e: print(f"警告: {filename} 中找不到 {sheet_name}!{cell_ref} - {str(e)}") row_data.append("N/A") output_ws.append(row_data) except Exception as e: print(f"处理 {filename} 失败: {str(e)}") continue output_wb.save(output_file) print(f"处理完成,结果已保存到: {output_file}") # 使用示例 if __name__ == "__main__": # 配置要读取的单元格(所有文件都按这个规则读取) cells_to_read = [ ("Sheet1", "A1", "客户名称"), ("Sheet1", "B2", "订单金额"), ("数据汇总", "C3", "日期") ] batch_read_unknown_excel( input_folder="./excel_files", # 存放Excel的文件夹 output_file="./output/汇总结果.xlsx", target_cells=cells_to_read ) ``` ### 关键改进说明: 1. **自动识别文件**:无需预先配置文件名,自动处理文件夹内所有`.xlsx/.xls`文件 2. **统一读取规则**:所有文件都按照`target_cells`参数指定的位置读取 3. **错误处理增强**: - 跳过无法读取的文件 - 对缺失的sheet或单元格标记为"N/A" 4. **灵活输出**:始终保持"文件名"作为第一列,后续列按配置顺序排列 ### 注意事项: - 所有Excel文件需要有**相同的sheet结构**(但会跳过缺失的sheet) - 如需为不同文件设置不同的读取规则,需要额外添加文件名匹配逻辑
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值