怎么用NuGet和配置log4net就不介绍了,直接上代码(QRDecodeDemo.zip)。
(Visual Studio 2015 下的项目,用的.NET Framework 4.5.2)
吐槽一下博客园无法插入代码块…… 排版丑点凑合一下,如下:
using System;
using System.IO;
using System.Drawing;
using System.Configuration;
using ThoughtWorks.QRCode.Codec;
using ThoughtWorks.QRCode.Codec.Data;
using log4net;
namespace QRDecodeConsoleApp
{
class Program
{
/// <summary>
/// 私有日志对象
/// </summary>
private static readonly ILog logger = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
/// <summary>
/// 识别指定目录下的全部二维码图片(PNG)
/// </summary>
/// <param name="args"></param>
static void Main(string[] args)
{
try
{
string[] files;
if (args.Length > 0)
{
files = Directory.GetFiles(args[0], "*.png");//CMD里exe后的参数
}
else
{
//读取指定路劲(QRDecodeConsoleApp.exe.config里配置的路劲)
files = Directory.GetFiles(ConfigurationManager.AppSettings["QRImgPath"], "*.png");
}
//存放结果的文件
string filePath = "txtResult" + DateTime.Now.ToString("yyyyMMddHHmmssfff") + ".config";
CreateTxtFile(filePath, "");//初始为空
//一个个读取并追加到记录文件
for (int i = 0; i < files.Length; i++)
{
File.AppendAllText(filePath, CodeDecoder(files[i]) + "\t" + files[i] + "\n");//追加到文件里记录
logger.Info("第" + i + "个识别成功");
Console.WriteLine("第" + i + "个识别成功");
}
Console.WriteLine("识别完成,按任意键退出");
Console.ReadLine();
}
catch (Exception ex)
{
Console.WriteLine("识别出错:" + ex.Message);
logger.Error("识别出错");
logger.Error("异常描述:\t" + ex.Message);
logger.Error("异常方法:\t" + ex.TargetSite);
logger.Error("异常堆栈:\t" + ex.StackTrace);
Console.ReadLine();
}
}
/// <summary>
/// 读取图片文件,识别二维码
/// </summary>
/// <param name="filePath">图片文件路劲</param>
/// <returns>识别结果字符串</returns>
public static string CodeDecoder(string filePath)
{
string decoderStr;
try
{
if (!System.IO.File.Exists(filePath))//判断有没有需要读取的主文件夹,如果不存在,终止
return null;
Bitmap bitMap = new Bitmap(Image.FromFile(filePath));//实例化位图对象,把文件实例化为带有颜色信息的位图对象
QRCodeDecoder decoder = new QRCodeDecoder();//实例化QRCodeDecoder
decoderStr = decoder.decode(new QRCodeBitmapImage(bitMap), System.Text.Encoding.UTF8);//通过.decoder方法把颜色信息转换成字符串信息
}
catch (Exception ex)
{
throw ex;
}
return decoderStr;//返回字符串信息
}
/// <summary>
/// 创建文本类型文件
/// </summary>
/// <param name="filename">文件名(.config、.txt文件等)</param>
/// <param name="txtStr">文件内容字符串</param>
static void CreateTxtFile(string filename, string txtStr)
{
try
{
FileStream fs = new FileStream(filename, FileMode.Create);//生成文件
byte[] data = System.Text.Encoding.UTF8.GetBytes(txtStr);//获得字节数组
fs.Write(data, 0, data.Length);//开始写入
fs.Flush();//清空缓冲区
fs.Close();//关闭流
}
catch (Exception ex)
{
throw ex;
}
}
}
}