首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用PySal计算莫兰的I?

用PySal计算莫兰的I?
EN

Stack Overflow用户
提问于 2017-06-14 20:55:56
回答 1查看 1.4K关注 0票数 3

对于Uni的一个赋值,我们必须使用文件来计算莫兰的I。我已经找到了一个示例代码,并从那里开始操作,但我得到了错误消息“‘PySal’object has no attribute 'by_col'”

任何想法都将不胜感激。该数据集是纽约的一个文本文件,"T0_MINC“属性是包含不同地区的中位数家庭收入的列。脚本附在下面

代码语言:javascript
复制
import os
import pysal
import numpy as np

os.chdir = ("C:\\Users\\hsv0336\\Desktop")
wd = os.getcwd()

w = pysal.open(wd + "\\Rook.gal")
f = pysal.open(wd + "\\NewYorkData.txt")
y = np.array(f.by_col["T0_MINC"])

mi = pysal.Moran(y, w, two_tailed=False)

我正在使用的示例脚本位于此链接中的"Moran“下:http://pysal.readthedocs.io/en/latest/users/tutorials/autocorrelation.html#moran-s-i

EN

回答 1

Stack Overflow用户

发布于 2017-06-16 02:03:11

pysal.open尝试根据扩展名并通过检查文件来确定文件类型。pysal.open返回的类型并不总是清晰的,应该使用内置类型函数进行检查。在你的例子中,它返回一个普通的python文件对象,这意味着pysal不能为你解析它。只有当PySAL将您的文件识别为DataTable时,"by_col“方法才可用。

支持的DataTable类型包括带有特殊"GeoDa“头的.csv、.dbf或.txt文件。GeoDa标题包含第一行中的数据行数和列数,以及第二行中的列名。

例如,示例STL_HOM.txt数据集的前几行。其具有78个数据行和4列。

代码语言:javascript
复制
78,4
"FIPSNO","HR8488","HR8893","HC8488"
17107,1.290722,1.624458,2

您可以将文件重新格式化为受支持的DataTable类型之一,也可以编写自己的代码来解析文本文件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44545447

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档