SPSS/Python - 访问变量标签



我正在尝试使用Python在SPSS的循环中访问变量标签。for 循环遍历一系列变量,删除 1-3 并按 5 个变量的序列重命名 4 和 5。这工作正常,但是现在尝试通过SPSS访问变量标签时,我遇到了" unicode对象没有属性键"错误。

认识到我需要以某种方式引用数组中的键而不是字符串,但作为一名新手程序员,我正在努力弄清楚如何更新我现有的代码:

begin program.
import spss, spssaux
vdict=spssaux.VariableDict()
mylist=vdict.range(start="M10", end="ENDOK_D")
nvars = len(mylist)
mycounter = 1
durations = ""
for i in range(nvars):
  myvar = mylist[i]
  if (mycounter < 4): 
    spss.Submit("delete variables %s." % myvar)
    mycounter +=1
  elif (mycounter == 4): 
    varlabel = mylist[i].VariableLabel 
    spss.Submit('variable labels %s "%s" [TimeStamp]' % (myvar,varlabel) + ".")
    if (myvar.endswith("_C")): mynewvar = myvar[:-2] + "_TS"
    spss.Submit("rename variables (%s = %s)" % (myvar,mynewvar) + ".")
    spss.Submit("formats %s (DATETIME28.4)" % (mynewvar) + ".")
    mycounter +=1
  elif (mycounter == 5): 
    varlabel = mylist[i].VariableLabel 
    spss.Submit('variable labels %s "%s" [TimeStamp]' % (myvar,varlabel) + ".")
    if (myvar.endswith("_D")): mynewvar = myvar[:-2] + "_TSD"
    spss.Submit("rename variables (%s = %s)" % (myvar,mynewvar) + ".")
    durations += mynewvar + " "
    mycounter = 1
spss.Submit("alter type %s (F4.0)" % durations + ".")
end program.

任何帮助将不胜感激。

spss.Submit('variable labels %s "%s" [TimeStamp]' % (myvar,varlabel) + ".")是给你带来麻烦的原因。

[TimeStamp] 位基本上是告诉 python 在字典中查找名为"TimeStamp"的键,但在 [TimeStamp] 之前,它没有找到正确的数据结构 - 即字典 - 而是一个没有键的字符串。也许这可能会更清楚:

myDict = {
          "varname": "myVariable", 
          "label": "This is myVariable's label!", 
          "TimeStamp": "20190204-0814"
          }
print (myDict["varname"])
print (myDict["TimeStamp"])
>>> myVariable
>>> 20190204-0814

Python正在寻找这样的数据结构,并希望查找键"TimeStamp"。现在,我假设您只想让您的标签读作"分配了任何变量标签 [时间戳]"?

只需将两行更改为

spss.Submit('variable labels %s "%s" + " [TimeStamp]"' % (myvar,varlabel) + ".")

最新更新