gpt4 book ai didi

Perl 数据解析和插入行

转载 作者:行者123 更新时间:2023-12-02 05:19:52 25 4
gpt4 key购买 nike

致全世界的 Perl 大师!

我有一个这样的文件要解析并想制作......

从第一列开始,ID,外显子信息,起始位置,结束位置和方向。 ID遇到数字就加1。

1   9239    712 8571    +
1 start_codon 712 714 +
1 stop_codon 8569 8571 +
2 3882 24137 24264 +
2 start_codon 24137 24139 +
3 3882 24322 24391 +
4 3882 24490 26064 +
4 stop_codon 26062 26064 +
5 4972 26704 26740 +
5 start_codon 26704 26706 +
6 4972 26814 27170 +
7 4972 27257 27978 +
7 stop_codon 27976 27978 +
8 10048 40161 41114 -
8 start_codon 41112 41114 -
8 stop_codon 40161 40163 -
9 272 43167 43629 -
9 stop_codon 43167 43169 -
10 272 43755 44059 -
10 start_codon 44057 44059 -

像这样....

1   9239    *712*   *8571*  +
1 start_codon 712 714 +
1 stop_codon 8569 8571 +
*X 9239 712 8571 +*
2 3882 *24137* 24264 +
2 start_codon 24137 24139 +
3 3882 24322 24391 +
4 3882 24490 *26064* +
4 stop_codon 26062 26064 +
*X 3882 24173 26064 +*
5 4972 *26704* 26740 +
5 start_codon 26704 26706 +
6 4972 26814 27170 +
7 4972 27257 *27978* +
7 stop_codon 27976 27978 +
*X 4972 26704 27978 +*
8 10048 *40161* *41114* -
8 start_codon 41112 41114 -
8 stop_codon 40161 40163 -
*X 10048 40161 41114 -*
9 272 *43167* 43629 -
9 stop_codon 43167 43169 -
10 272 43755 *44059* -
10 start_codon 44057 44059 -
*X 272 43167 44059 -*

必须添加以 X 开头的每一行,但以我的技能我不能... :(

问题是第二列中的每个外显子编号忽略“start_codon”和“end_codon”,必须获得星号 * 之间的最小编号外显子位置和最大编号外显子位置。

这是我解析数据的基本代码......但我想,必须从头开始重新编码(我不知道如何插入“X”行)

(抱歉,我删除了代码,因为它不够好,可能会造成混淆...)

世界上的 Perl 大师,你能帮帮我吗???

谢谢!!

当 TLP 出现时,我放回了我的代码。虽然它的尴尬代码

use strict;

if (@ARGV != 1) {
print "Invalid arguments\n";
print "Usage: perl min_max.pl [exon_output_file]\n";
exit(0);
}

my $FILENAME = $ARGV[0];
my $exonid = 0;
my $exon = "";
my $startpos = 0;
my $endpos = 0;
my $strand = "";
my $min_pos = 0;
my $max_pos = 0;

open (DATA, $FILENAME);

while (my $line = <DATA>) {
chomp $line;

if ($line ne "") {
if ($line =~ /^(.+)\t(.+)\t(.+)\t(.+)\t(.+)/) {
$exonid = $1;
$exon = $2;
$startpos = $3;
$endpos = $4;
$strand = $5;
}
if ($exon =~ /\d+/) {
print $exonid,"\t",$exon,"\t",$startpos,"\t",$endpos,"\t",$strand,"\n";
} else {
print $exonid,"\t",$exon,"\t",$startpos,"\t",$endpos,"\t",$strand,"\n";
}
}
}

close (DATA);
exit;

如何比较最大值和最小值....

最佳答案

基本上你所做的就是遍历这些行,跳过你不想要的那些(即第 2 列中没有数字),记住同一组中每个新行的最小值/最大值,以及当第 2 列数字更改时你打印并重新开始。使用此解决方案,您还必须在最后手动打印最后一组。

此代码使用内部 DATA演示数据的文件句柄。只需更改 <DATA><>像这样在目标输入文件上使用:perl script.pl inputfile

use strict;
use warnings;
use List::Util qw(min max);

my $print;
my ($min, $max, $id);
while (<DATA>) { ###### change to <> to run on input file
my @line = split;
if ($line[1] !~ /^\d+$/) { # if non-numbers in col 2
print; # print line
next; # skip to next line
}
if (!defined($id) or $id != $line[1]) { # New dataset!
say $print if $print; # Print and reset
$id = $line[1];
$min = $max = undef;
}
$min = min($min // (), @line[2,3]); # find min/max, skip undef
$max = max($max // (), @line[2,3]);
$print = join "\t", "X", $line[1], $min, $max; # buffer the print
}
print $print;

__DATA__
1 9239 712 8571 +
1 start_codon 712 714 +
1 stop_codon 8569 8571 +
2 3882 24137 24264 +
2 start_codon 24137 24139 +
3 3882 24322 24391 +
4 3882 24490 26064 +
4 stop_codon 26062 26064 +
5 4972 26704 26740 +
5 start_codon 26704 26706 +
6 4972 26814 27170 +
7 4972 27257 27978 +
7 stop_codon 27976 27978 +
8 10048 40161 41114 -
8 start_codon 41112 41114 -
8 stop_codon 40161 40163 -
9 272 43167 43629 -
9 stop_codon 43167 43169 -
10 272 43755 44059 -
10 start_codon 44057 44059 -

输出:

9239    712     8571
3882 24137 26064
4972 26704 27978
10048 40161 41114
272 43167 44059

关于Perl 数据解析和插入行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14039330/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com