利用python将二值csv格式转换为矩阵
#!/usr/bin/env python
# coding:utf-8
#import pandas as pd, numpy as np;
'''
将csv文件转换为对应的邻接矩阵mat
'''
from numpy import *;
def protein_complexes_trans():
file = open('protein_complexes.csv');
filePro = open('complexes', 'a');
fileTarget = open('targets(complexes)','a');
fileInter = open('protein_complexes_interaction_matrix', 'a');
proteins = [];
targets = [];
while 1:
line = file.readline();
if not line:
break;
token = line.split(';');
targ = token[1].split(',');
for i in range(0,len(targ)):
targets.append(targ[i]);
proteins.append(token[0]);
file.seek(0); #将指针重置回第一行
proArr = unique(array(proteins)).tolist(); #去重,并删去最后一项(标题)
tarArr = unique(array(targets)).tolist(); #删去最后
#mat为邻接矩阵
mat = zeros((len(proArr),len(tarArr)), dtype = int16);
while 1:
line = file.readline();
if not line:
break;
token = line.split(';');
targ = token[1].split(',');
row = proArr.index(token[0]);
for i in range(0, len(targ)):
col = tarArr.index(targ[i]);
mat[row][col] = 1;
#输出药物和靶向的列表
for i in proArr:
filePro.write('%s\n' % i);
for i in tarArr:
fileTarget.write('%s\n' % i);
print "%d&%d" % (len(proArr), len(tarArr));
interMat = mat.tolist();
#将矩阵写入文件
for i in range(0, len(proArr)):
fileInter.write('%s\n' % (str(interMat[i])));
return 0;
def drugs_targets_trans():
#print 'hello world';
file = open('drugs_targets_sum');
fileDrug = open('drugs', 'a');
fileTarget = open('targets','a');
fileInter = open('drugs_targets_interaction_matrix', 'a');
drugs = [];
targets = [];
while 1:
line = file.readline();
if not line:
break;
token = line.split(';');
targ = token[1].split(',');
for i in range(0,len(targ)):
targets.append(targ[i]);
drugs.append(token[0]);
file.seek(0); #将指针重置回第一行
drugArr = unique(array(drugs)).tolist(); #去重,并删去最后一项(标题)
tarArr = unique(array(targets)).tolist(); #删去最后
#mat为邻接矩阵
mat = zeros((len(drugArr),len(tarArr)), dtype = int16);
while 1:
line = file.readline();
if not line:
break;
token = line.split(';');
targ = token[1].split(',');
row = drugArr.index(token[0]);
for i in range(0, len(targ)):
col = tarArr.index(targ[i]);
mat[row][col] = 1;
#输出药物和靶向的列表
for i in drugArr:
fileDrug.write('%s\n' % i);
for i in tarArr:
fileTarget.write('%s\n' % i);
interMat = mat.tolist();
for i in range(0, len(drugArr)):
fileInter.write('%s\n' % (str(interMat[i])));
#protein_complexes_trans();
drugs_targets_trans();
利用python将二值csv格式转换为矩阵的更多相关文章
- python 爬虫数据存入csv格式方法
python 爬虫数据存入csv格式方法 命令存储方式:scrapy crawl ju -o ju.csv 第一种方法:with open("F:/book_top250.csv" ...
- 利用Python计算π的值,并显示进度条
利用Python计算π的值,并显示进度条 第一步:下载tqdm 第二步;编写代码 from math import * from tqdm import tqdm from time import ...
- Mac OS X将CSV格式转换为Excel文档格式,Excel转CSV中文乱码问题
一:在Mac上假设你使用Excel打开windows导出的CSV格式文档.你会发现表格中全部的的内容都显示在A列. 那么,怎样恢复正常呢,你能够将CSV格式的文档导入到Excel文档中,这样就正常显示 ...
- 10、OpenCV Python 图像二值化
__author__ = "WSX" import cv2 as cv import numpy as np #-----------二值化(黑0和白 255)---------- ...
- python图片二值化提高识别率
import cv2from PIL import Imagefrom pytesseract import pytesseractfrom PIL import ImageEnhanceimport ...
- opencv python 图像二值化/简单阈值化/大津阈值法
pip install matplotlib 1简单的阈值化 cv2.threshold第一个参数是源图像,它应该是灰度图像. 第二个参数是用于对像素值进行分类的阈值, 第三个参数是maxVal,它表 ...
- 利用Python制作二维码
利用简单的Python代码制作二维码 一.制作工具 安装Python环境 + PyCharm编译器. 二.电脑系统 本人win10 + Python3.7.0 + PyCharm. 三.写代码前先下载 ...
- 利用mysqldump命令导出为csv格式文件
解决方法: 先导出为txt文件,其内容是以逗号“,”分隔的,得到txt文件后,再自行处理为.csv或者.xls文件. 参数说明: -t, --no-create-info Don't write ...
- python习题_读写csv格式的文件
1.读写TXT文件 # *_* coding : UTF-8 *_* # 开发人员 : zfy # 开发时间 :2019/7/7 16:26 # 文件名 : lemon_10_file.PY # 开发 ...
随机推荐
- iOS 多线程GCD简介
一.简介 1.1 GCD (Grand Central Dispatch )是Apple开发的一个多核编程的解决方法. Grand 含义是“伟大的.宏大的”,Central含义“中央的”,Dispat ...
- SharePoint 2013 网站搜索规则的使用示例
前言 SharePoint 2013搜索中,有一个非常好用的细化搜索结果的功能,就是“查询规则”.可以通过对于某些特定查询时,起到细化显示结果的作用.下面,我们简单的介绍一下该功能的使用和效果. 1. ...
- win7显示不是正版系统的解决方法
十一长假回来,打开电脑就变成这样了.现在的我已经学会了不再逃避问题,要学着解决问题,就在网上搜集了有关这方面的信息.说是下载一个激活工具就可以了.我就试着下载了,但是不知道为什么下了几个激活工具都不管 ...
- iOS项目groups和folder的区别(组和文件夹)
在引用一个第三方框架的时候,已经拖进去了,但是引用框架里面的文件时,竟然报错说找不到.......查了一下,原来在拖进去时没有注意group和folder的选择! 其实仔细观察一下,不难发现,以gro ...
- IOS-WebViewJavascriptBridge使用说明
下面来说一下WebViewJavascriptBridge在ios端怎么样使用. 首先确保一份已经配好功能的html文件. 1.初始化一个webview(viewdidload) UIWebView* ...
- Hadoop学习
Hadoop: 大数据里面的公认的解决方案标准 链接推荐:http://www.powerxing.com/install-hadoop/ 第一天 Hadoop的基本概念 伪分布式集群安装 hdfs ...
- Java源码分析之ArrayList
ArrayList是以数组为基准的容器类,和LinkedList(链表)正好相反.因而ArrayList拥有更好的查找性能,增删操作则差一些.ArrayList封装了对于常规数组的操作,同时可以自动扩 ...
- There is insufficient system memory to run this query 错误
服务器环境大致情况如下: 操作系统: Microsoft Windows Server 2003 R2 Enterprise Edition Service Pack 2 数据库 : Mic ...
- 简述SQL2008部署多实例集群(学习)
数据库集群 集群的存在意义是为了保证高可用.数据安全.扩展性以及负载均衡. 什么是集群? 由二台或更多物理上独立的服务器共同组成的"虚拟"服务器称之为集群服务器.一项称做M ...
- YII2 项目安装步骤及异常记录
项目环境: 操作系统:windows 7 版本管理:git 该项目我是在mac上面创建的,mac上面的环境也是一波三折啊!但我同事的环境是在windows上面,因为是前端同学,所以只好我再次操刀了.. ...