Seqanswers Leaderboard Ad

Collapse

Announcement

Collapse
No announcement yet.
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • Renaming fasta headers - string within a string issue

    Hi Everyone,

    I am in the midst of renaming some fasta headers to include the chromosomes they have been mapped to (from a tab delimited txt file). I don't have any problems setting up the hash for the scaffold and chromosome locations...the problem is that I have some short strings contained in longer strings (scaffold1 and scaffold10 and scaffold100). Usually I would add "$" to the end of my search term (/scaffold1$/) and thereby indicate the end of the search string, but I'm not sure how to make use of this when the search term is a variable ($hash{$scaff/$/}). Advice?

    Below is my script so far...and TIA!

    Code:
    #!/bin/bash/perl
    #mod-header2include-chrom.pl
    #This script is intended to read in a fasta file and a tab-delimited file and use the information from the tab-delimited file to modify the header.
    #In this case, we are appending to the header (e.g. "scaffold671") the chromosome to which it has been mapped and the number of genes on this scaffold.
    
    use strict;
    use warnings;
    
    open (DATA, "<genome-assoc-chromosomes.txt") or die "Could not open genome chromosome mapping data: $!\n";
    open (FASTA, "<scafSeq.FG.fill") or die "Could not open Fasta file: $!\n";
    
    my %hash;
    
    while (<DATA>)
    {
    chomp;
    if ($_ =~ "scafold"){ #skip header - scafold is spelled incorrectly on purpose;
    next;
    }
    else {
    my ($key, $chrom, $len, $gene) = split /\t/;
    $hash{$key} = $chrom;
    }
    }
    
    while (<FASTA>){
    
    my $line = $_;
    chomp ($line);
    if ( defined $hash{$line} ) {
    print "$line-$hash{$line}";
    }
    else { print $line; }
    
    }

  • #2
    Hi,
    Kindly upload a sample of both files (scafSeq.FG.fill and genome-assoc-chromosomes.txt). Without the fasta file, I am wondering how the following:
    while (<FASTA>){
    my $line = $_;
    chomp ($line);
    if ( defined $hash{$line} ) {


    reads in the header line with ">" from "<scafSeq.FG.fill"

    does the variable $key in "$hash{$key} = $chrom;" contain ">"?

    Comment

    Latest Articles

    Collapse

    • seqadmin
      Recent Advances in Sequencing Analysis Tools
      by seqadmin


      The sequencing world is rapidly changing due to declining costs, enhanced accuracies, and the advent of newer, cutting-edge instruments. Equally important to these developments are improvements in sequencing analysis, a process that converts vast amounts of raw data into a comprehensible and meaningful form. This complex task requires expertise and the right analysis tools. In this article, we highlight the progress and innovation in sequencing analysis by reviewing several of the...
      05-06-2024, 07:48 AM
    • seqadmin
      Essential Discoveries and Tools in Epitranscriptomics
      by seqadmin




      The field of epigenetics has traditionally concentrated more on DNA and how changes like methylation and phosphorylation of histones impact gene expression and regulation. However, our increased understanding of RNA modifications and their importance in cellular processes has led to a rise in epitranscriptomics research. “Epitranscriptomics brings together the concepts of epigenetics and gene expression,” explained Adrien Leger, PhD, Principal Research Scientist...
      04-22-2024, 07:01 AM

    ad_right_rmr

    Collapse

    News

    Collapse

    Topics Statistics Last Post
    Started by seqadmin, Yesterday, 06:57 AM
    0 responses
    12 views
    0 likes
    Last Post seqadmin  
    Started by seqadmin, 05-06-2024, 07:17 AM
    0 responses
    16 views
    0 likes
    Last Post seqadmin  
    Started by seqadmin, 05-02-2024, 08:06 AM
    0 responses
    19 views
    0 likes
    Last Post seqadmin  
    Started by seqadmin, 04-30-2024, 12:17 PM
    0 responses
    24 views
    0 likes
    Last Post seqadmin  
    Working...
    X