blob: 6755adbd3c3410b803f08a0a122b448ca97b6f66 (
plain)
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
|
import re
import sys
## generate the html page for the top genes
## put gene names and alias in a dictionary
#ncbi_gene_symb_syno_name_txid9606_absCnt_sorted_absCnt_sorted_absCnt_absCnt_sorted.txt
if (len(sys.argv) != 2):
print ("please provide the name of a sorted gene abstract count file")
sys.exit()
geneNames={}
with open (sys.argv[1],"r") as f:
for line in f:
(genes, count)=line.strip().split("\t")
gene=genes.split("|")
names=re.sub(r'^.*?\|', "", genes)
geneNames[gene[0]]=names.strip().replace("|", "; ")
out=str()
html=str()
with open("./topGeneAbstractCount.tab" ,"r") as gc:
cnt=0
for line in gc:
cnt+=1
line=re.sub(r'^\s+','',line)
print (line)
pmid_cnt, symb=line.strip().split()
out+= symb+"\t"+geneNames[symb]+"\n"
html+="<li><a href=\"/showTopGene?topGene="+symb+"\">"+symb+"</a> <span style=\"font-size:small; color:grey\">("+geneNames[symb]+")</span><br>\n"
if cnt==200:
break
with open("topGene_symb_alias.txt", "w+") as tg:
tg.write(out)
tg.close()
htmlout='''
{% extends "layout.html" %}
{% block content %}
<h3> Top addiction related genes </h3>
<br>
These genes are ranked by the number of PubMed abstracts that contain the name of the gene and one or more addiction related keyword.
<hr>
<ol>''' + html + '''
</ol>
{% endblock %}
'''
with open("./templates/topAddictionGene.html", "w+") as html_f:
html_f.write(htmlout)
html_f.close()
|