![](/img/trans.png)
[英]SSIS: How to read, omit by matching, and write records from pipe delimited flat file in C#
[英]SSIS Filtering records from flat file
我正在尝试过滤包含字符串“Order”的平面文件中的记录,然后将结果导入到 excel 文件中。
我为此使用了条件拆分组件,条件 FINDSTRING(MyColumn,"Order",1) > 0 但它不起作用 - 结果没有导入任何记录。
我的平面文件中的行如下所示: 2020-01-01 11:51:00 3459 Order:1398 session:fr34skjdnn32kjsd ID:67889
你知道如何解决这个问题吗? 预先感谢您的帮助!
下面的代码只是如何读取文件的示例。 我需要查看更多的输入行才能让代码处理任何输入。 我已经解析这样的文本文件超过 45 年了,并且了解到一行输入永远不足以让这样的代码处理所有输入
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Text.RegularExpressions;
namespace ConsoleApplication1
{
class Program
{
const string FILENAME = @"c:\temp\test.txt";
static void Main(string[] args)
{
Order order = new Order();
List<Order> orders = order.ReadFile(FILENAME);
}
}
public class Order
{
public DateTime date { get; set; }
public string order { get; set; }
public string session { get; set; }
public string id { get; set; }
public List<Order> ReadFile(string filename)
{
StreamReader reader = new StreamReader(filename);
List<Order> orders = new List<Order>();
string line = "";
while ((line = reader.ReadLine()) != null)
{
Order newOrder = new Order();
orders.Add(newOrder);
string dateStr = line.Substring(0, 24);
newOrder.date = DateTime.ParseExact(dateStr, "yyyy-MM-dd hh:mm:ss ffff", System.Globalization.CultureInfo.InvariantCulture);
string pattern = @"(?'key'[^:]+):(?'value'[^\s]+)";
MatchCollection matches = Regex.Matches(line.Substring(24), pattern);
foreach (Match match in matches.Cast<Match>().AsEnumerable())
{
string key = match.Groups["key"].Value.Trim();
string value = match.Groups["value"].Value.Trim();
switch (key)
{
case "Order" :
newOrder.order = value;
break;
case "session":
newOrder.session = value;
break;
case "ID" :
newOrder.id = value;
break;
}
}
}
return orders;
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.