我有一个输出在python中使用稀疏矩阵,我需要将这个稀疏矩阵存储在我的硬盘中,我该怎么做呢?如果我应该创建一个数据库,那么我应该怎么做? 这是我的代码:Python:如何使用python存储稀疏矩阵?
import nltk
import cPickle
import numpy
from scipy.sparse import lil_matrix
from nltk.corpus import wordnet as wn
from nltk.corpus import brown
f = open('spmatrix.pkl','wb')
def markov(L):
count=0
c=len(text1)
for i in range(0,c-2):
h=L.index(text1[i])
k=L.index(text1[i+1])
mat[h,k]=mat[h,k]+1//matrix
cPickle.dump(mat,f,-1)
text = [w for g in brown.categories() for w in brown.words(categories=g)]
text1=text[1:500]
arr=set(text1)
arr=list(arr)
mat=lil_matrix((len(arr),len(arr)))
markov(arr)
f.close()
我需要存储这个“垫”的文件,并应访问使用坐标矩阵的值..稀疏矩阵的
结果就像这样的:`稀疏矩阵的结果是这样的:
(173, 168) 2.0 (173, 169) 1.0 (173, 172) 1.0 (173, 237) 4.0 (174, 231) 1.0 (175, 141) 1.0 (176, 195) 1.0
但是当我把它保存到一个文件并阅读我越来越像这样一样:
(0, 68) 1.0 (0, 77) 1.0 (0, 95) 1.0 (0, 100) 1.0 (0, 103) 1.0 (0, 110) 1.0 (0, 112) 2.0 (0, 132) 1.0 (0, 133) 2.0 (0, 139) 1.0 (0, 146) 2.0 (0, 156) 1.0 (0, 157) 1.0 (0, 185) 1.0
你心里有一个特定的数据库?这些矩阵的大小是多少?你有没有考虑过sqlite(Python有内置的支持)? – NullUserException 2011-03-02 06:26:07
我是一个新手,我不太了解,嗯,我只是想找到一个解决方案,将我的矩阵存储在硬盘上,我不想运行程序来一次又一次地生成矩阵,如果我可以存储矩阵我可以在下一次参考值的矩阵..请建议我..谢谢:) – 2011-03-02 09:06:56
请参阅以下格式化您的代码,以便它是可读的:http://stackoverflow.com/editing-help,但基本上只需在每行代码前放4个空格,然后缩进,否则确保在代码和任何普通文本之间留下空行。 – JoshAdel 2011-03-02 19:52:37