无法使用pyral的rest api python提取项目的所有特征数据

时间:2020-11-12 02:54:33

标签: python api rest rally pyral

我正在尝试使用pyral模块读取Rally中项目的所有特征数据。结果集总数为1358,在读取约700条记录后,脚本将引发错误,如下所述。

rally1 = Rally(entity='PortfolioItem_Feature',server='rally1.rallydev.com',fetch=True, user='xxx', password='', workspace='xxx/yyy', project='ABC')
features = rally1.get('Feature',fetch="True",pagesize=2000,start=0,limit=5000)

for feature in features:
    #a=pd.DataFrame(feature)
    print(feature.details())

输出:

PortfolioItem/Feature result set, totalResultSetSize: 1358, startIndex: 1  pageSize: 2000  current Index: 0
I'm getting the following errors:

File "C:\Users\nis\AppData\Roaming\Python\Python38\site-packages\pyral\entity.py", line 397, in details
    (attr_name, cln, value.oid, value.UserName, value.DisplayName)
  File "C:\Users\nis\AppData\Roaming\Python\Python38\site-packages\pyral\entity.py", line 139, in __getattr__
    raise UnreferenceableOIDError("%s OID %s" % (rallyEntityTypeName, self.oid))
pyral.entity.UnreferenceableOIDError: User OID 44012386960

所以,我有以下问题:

  1. 如何解决此错误,这意味着跳过阅读该特定字段以获取要素属性或将其替换为空结果集的情况。
  2. 如何在不出现上述错误的情况下将(a)(b)PortfolioItem / Feature结果集转换为数据帧。

我正在使用以下代码,该脚本的读数也约为。 700记录并引发与上述相同的错误。我尝试使用错误处理,但仍会在遇到错误时停止读取。任何帮助将不胜感激。

r=pd.DataFrame()
for feature in features:
 a= {
 'OID': feature.oid,
 'FeatureID':feature.FormattedID,
 'Creation_Date': feature.CreationDate,
  'Project_Name': feature.Project.Name,
  'AcceptedLeafStoryPlanEstimateTotal':feature.AcceptedLeafStoryPlanEstimateTotal,
  'AcceptedLeafStoryPlanEstimateTotal':feature.AcceptedLeafStoryPlanEstimateTotal,
  'Feature_payload':feature._ref,
  'Created by':feature.CreatedBy.DisplayName
 }
 #print(a.keys())
 #print(a.values())
 r=r.append(a,ignore_index=True,sort=False)
 print(r)

2 个答案:

答案 0 :(得分:0)

在我看来,ID 为 44012386960 的对象已损坏,因此您必须跳过它。

for feature in features:
    if feature.oid == 44012386960:
        continue
    print(feature.details())

我假设您的错误是一个错误的 featureoid,因为它也发生在您仅使用 feature.oid 的第二个循环中,但也有可能是 feature.CreatedBy 是问题,因为您的错误消息表明它是一个错误的用户 oid .在这种情况下,我的建议是在循环中打印 feature.CreatedBy.oid 以找到坏的并将我的 if 更改为 if feature.CreatedBy.oid == 44012386960: continue

答案 1 :(得分:-2)

我在 python 中使用三元运算符解决了这个问题,如下所示:

feature_name = '' if feature.Feature is None else feature.Feature.Name

问题是每当 Rally rest api 无法引用导致错误的特定功能的 oid 时。