File: obicount.py

package info (click to toggle)
obitools 1.2.13%2Bdfsg-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 4,652 kB
  • sloc: python: 18,199; ansic: 1,542; makefile: 98
file content (59 lines) | stat: -rw-r--r-- 1,827 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#!/usr/bin/python3
'''
:py:mod:`obicount`: counts the number of sequence records 
=========================================================

.. codeauthor:: Eric Coissac <eric.coissac@metabarcoding.org>

:py:mod:`obicount` counts the number of sequence records and/or the sum of the ``count`` attributes.

*Example:*

    .. code-block:: bash
        
        > obicount seq.fasta  

    Prints the number of sequence records contained in the ``seq.fasta`` 
    file and the sum of their ``count`` attributes.
'''

from obitools.options import getOptionManager
from obitools.format.options import addInputFormatOption

def addCountOptions(optionManager):
    group=optionManager.add_option_group('Obicount specific options')
    group.add_option('-s','--sequence',
                             action="store_true", dest="sequence",
                             default=False,
                             help="Prints only the number of sequence records."
                             )
 
    group.add_option('-a','--all',
                             action="store_true", dest="all",
                             default=False,
                             help="Prints only the total count of sequence records (if a sequence has no `count` attribute, its default count is 1) (default: False)."
                             )


if __name__ == '__main__':
    optionParser = getOptionManager([addCountOptions,addInputFormatOption], progdoc=__doc__)
    
    (options, entries) = optionParser()
    
    count1=0
    count2=0
    
    for s in entries:
        count1+=1
        if 'count' in s:
            count2+=s['count']
        else:
            count2+=1
            
    if options.all==options.sequence:
        print(count1,count2)
    elif options.all:
        print(count2)
    else:
        print(count1)