从多个CSV文件中提取几种模式

如何解决从多个CSV文件中提取几种模式

我是编程新手,我想为perl中的以下函数编写代码。

在每个行格式如下的csv文件中,我有几个CSV文件(1.csv,2.csv,3.csv,4.csv ...)。

<time,id1,id2,id3,filename> :

202008110100,10819066580072,2147858602,Afile.txt
202008110110,12819066589761,AC987678,Bfile.txt
202008110120,8927489178,AC398761,Bfile.txt
202008110130,29274125780232,3829271910,AC119651,Cfile.txt
.
.
.
#id1,id3 might be blank sometimes.

我有这样的输入:

<starttime,endtime,id3>:
#id1,id3 might be **0**
eg):202008110105,202008110115,0

如果id1id2id3 = 0,则忽略该值,仅匹配非零的id

并在timestarttime期间提取endtime

我期望这样的匹配输出:

1.csv:Afile.txt

以下是我写的内容,但似乎有问题...有人可以帮助我吗?

my $dir = <C:/Windows/Users/USER/Documents/Perlprogram>;
@files = ("1.csv","2.csv,3.csv,4.csv");

foreach $file (@files) {        
print "$file\n" if -f $file;
open(IN,"<./$file") or die("Error");
@before = <IN>;
close(IN);

@after = grep(/$greplist/,@before);
foreach $after (@after) {
print "$after\n";
}
sub after {
    $time = $_[6];
    if ($time >= $starttime and $time <=$endtime){
        open(OUT,">>./search_result.txt");
        print($file,$_[4]);
        print(OUT $_[4]);
        close(OUT);
    }
}           

解决方法

似乎有问题...

@files = ("1.csv","2.csv,3.csv,4.csv");

除语法外,第一个文件之后的文件名未正确引用。

正如北极熊所说,$greplist未定义。假设将其设置为您称为 input 的内容,我们可以使用

获取各个字段
($starttime,$endtime,$id1,$id2,$id3) = split ',',$greplist;

程序的其余部分有些不连贯;您可以将行@before = <IN>;替换为

    while (<IN>)
    {
        @_ = split ','; # split the CSV line to the values
        print $_[4] if  !$id1 || $_[1] == $id1
                    and !$id2 || $_[2] == $id2
                    and !$id3 || $_[3] == $id3
                    and $starttime <= $_[0]
                    and $_[0] <= $endtime
    }

并删除foreach $file循环的其他内容。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?