本文整理汇总了Python中arelle.ModelRenderingObject.StructuralNode.hasOpenNode方法的典型用法代码示例。如果您正苦于以下问题:Python StructuralNode.hasOpenNode方法的具体用法?Python StructuralNode.hasOpenNode怎么用?Python StructuralNode.hasOpenNode使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类arelle.ModelRenderingObject.StructuralNode
的用法示例。
在下文中一共展示了StructuralNode.hasOpenNode方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: resolveTableAxesStructure
# 需要导入模块: from arelle.ModelRenderingObject import StructuralNode [as 别名]
# 或者: from arelle.ModelRenderingObject.StructuralNode import hasOpenNode [as 别名]
def resolveTableAxesStructure(view, table, tblAxisRelSet):
view.dataCols = 0
view.dataRows = 0
view.colHdrNonStdRoles = []
view.colHdrDocRow = False
view.colHdrCodeRow = False
view.colHdrRows = 0
view.rowHdrNonStdRoles = []
view.rowHdrCols = 0
view.rowHdrColWidth = [0,]
view.rowNonAbstractHdrSpanMin = [0,]
view.rowHdrDocCol = False
view.rowHdrCodeCol = False
view.zAxisRows = 0
view.aspectModel = table.aspectModel
view.zmostOrdCntx = None
view.modelTable = table
view.topRollup = {"x": ROLLUP_NOT_ANALYZED, "y": ROLLUP_NOT_ANALYZED}
view.aspectEntryObjectId = 0
xTopStructuralNode = yTopStructuralNode = zTopStructuralNode = None
# must be cartesian product of top level relationships
tblAxisRels = tblAxisRelSet.fromModelObject(table)
facts = view.modelXbrl.factsInInstance
view.breakdownNodes = defaultdict(list) # breakdown nodes
# do z's first to set variables needed by x and y axes expressions
for disposition in ("z", "x", "y"):
for i, tblAxisRel in enumerate(tblAxisRels):
definitionNode = tblAxisRel.toModelObject
if (tblAxisRel.axisDisposition == disposition and
isinstance(definitionNode, (ModelEuAxisCoord, ModelBreakdown, ModelDefinitionNode))):
if disposition == "x" and xTopStructuralNode is None:
xTopStructuralNode = StructuralNode(None, definitionNode, definitionNode, view.zmostOrdCntx, tableNode=table)
xTopStructuralNode.hasOpenNode = False
if isinstance(definitionNode,(ModelBreakdown, ModelClosedDefinitionNode)) and definitionNode.parentChildOrder is not None:
addBreakdownNode(view, disposition, definitionNode)
view.xTopRollup = CHILD_ROLLUP_LAST if definitionNode.parentChildOrder == "children-first" else CHILD_ROLLUP_FIRST
expandDefinition(view, xTopStructuralNode, definitionNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
view.dataCols = xTopStructuralNode.leafNodeCount
break
elif disposition == "y" and yTopStructuralNode is None:
yTopStructuralNode = StructuralNode(None, definitionNode, definitionNode, view.zmostOrdCntx, tableNode=table)
yTopStructuralNode.hasOpenNode = False
if isinstance(definitionNode,(ModelBreakdown, ModelClosedDefinitionNode)) and definitionNode.parentChildOrder is not None:
addBreakdownNode(view, disposition, definitionNode)
view.yAxisChildrenFirst.set(definitionNode.parentChildOrder == "children-first")
view.yTopRollup = CHILD_ROLLUP_LAST if definitionNode.parentChildOrder == "children-first" else CHILD_ROLLUP_FIRST
expandDefinition(view, yTopStructuralNode, definitionNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
view.dataRows = yTopStructuralNode.leafNodeCount
break
elif disposition == "z" and zTopStructuralNode is None:
zTopStructuralNode = StructuralNode(None, definitionNode, definitionNode, tableNode=table)
zTopStructuralNode._choiceStructuralNodes = []
zTopStructuralNode.hasOpenNode = False
addBreakdownNode(view, disposition, definitionNode)
expandDefinition(view, zTopStructuralNode, definitionNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
break
'''
def jsonDefaultEncoder(obj):
if isinstance(obj, StructuralNode):
return {'1StructNode': str(obj),
'2Depth': obj.structuralDepth,
'2Group': obj.breakdownNode(view.tblELR).genLabel(),
'3Label': obj.header() or obj.xlinkLabel,
'4ChildNodes': obj.childStructuralNodes}
raise TypeError("Type {} is not supported for json output".format(type(obj).__name__))
with io.open(r"c:\temp\test.json", 'wt') as fh:
json.dump({"x":xTopStructuralNode, "y":yTopStructuralNode, "z":zTopStructuralNode},
fh,
sort_keys=True,
ensure_ascii=False,
indent=2,
default=jsonDefaultEncoder)
'''
view.colHdrTopRow = view.zAxisRows + 1 # need rest if combobox used (2 if view.zAxisRows else 1)
for i in range(view.rowHdrCols):
if view.rowNonAbstractHdrSpanMin[i]:
lastRowMinWidth = view.rowNonAbstractHdrSpanMin[i] - sum(view.rowHdrColWidth[i] for j in range(i, view.rowHdrCols - 1))
if lastRowMinWidth > view.rowHdrColWidth[view.rowHdrCols - 1]:
view.rowHdrColWidth[view.rowHdrCols - 1] = lastRowMinWidth
#view.rowHdrColWidth = (60,60,60,60,60,60,60,60,60,60,60,60,60,60)
# use as wraplength for all row hdr name columns 200 + fixed indent and abstract mins (not incl last name col)
view.rowHdrWrapLength = 200 + sum(view.rowHdrColWidth[i] for i in range(view.rowHdrCols - 1))
view.dataFirstRow = view.colHdrTopRow + view.colHdrRows + len(view.colHdrNonStdRoles)
view.dataFirstCol = 1 + view.rowHdrCols + len(view.rowHdrNonStdRoles)
#view.dataFirstRow = view.colHdrTopRow + view.colHdrRows + view.colHdrDocRow + view.colHdrCodeRow
#view.dataFirstCol = 1 + view.rowHdrCols + view.rowHdrDocCol + view.rowHdrCodeCol
#for i in range(view.dataFirstRow + view.dataRows):
# view.gridView.rowconfigure(i)
#for i in range(view.dataFirstCol + view.dataCols):
# view.gridView.columnconfigure(i)
view.modelTable = table
# organize hdrNonStdRoles so code (if any) is after documentation (if any)
for hdrNonStdRoles in (view.colHdrNonStdRoles, view.rowHdrNonStdRoles):
iCodeRole = -1
for i, hdrNonStdRole in enumerate(hdrNonStdRoles):
if 'code' in os.path.basename(hdrNonStdRole).lower():
#.........这里部分代码省略.........
示例2: resolveTableAxesStructure
# 需要导入模块: from arelle.ModelRenderingObject import StructuralNode [as 别名]
# 或者: from arelle.ModelRenderingObject.StructuralNode import hasOpenNode [as 别名]
def resolveTableAxesStructure(view, table, tblAxisRelSet):
view.dataCols = 0
view.dataRows = 0
view.colHdrNonStdRoles = []
view.colHdrDocRow = False
view.colHdrCodeRow = False
view.colHdrRows = 0
view.rowHdrNonStdRoles = []
view.rowHdrCols = 0
view.rowHdrColWidth = [0,]
view.rowNonAbstractHdrSpanMin = [0,]
view.rowHdrDocCol = False
view.rowHdrCodeCol = False
view.zAxisRows = 0
view.aspectModel = table.aspectModel
view.zmostOrdCntx = None
view.modelTable = table
view.topRollup = {"x": ROLLUP_NOT_ANALYZED, "y": ROLLUP_NOT_ANALYZED}
view.aspectEntryObjectId = 0
xTopStructuralNode = yTopStructuralNode = zTopStructuralNode = None
# must be cartesian product of top level relationships
tblAxisRels = tblAxisRelSet.fromModelObject(table)
facts = view.modelXbrl.factsInInstance
# do z's first to set variables needed by x and y axes expressions
for disposition in ("z", "x", "y"):
for i, tblAxisRel in enumerate(tblAxisRels):
definitionNode = tblAxisRel.toModelObject
if (tblAxisRel.axisDisposition == disposition and
isinstance(definitionNode, (ModelEuAxisCoord, ModelBreakdown, ModelDefinitionNode))):
if disposition == "x" and xTopStructuralNode is None:
xTopStructuralNode = StructuralNode(None, definitionNode, view.zmostOrdCntx, breakdownTableNode=table)
xTopStructuralNode.hasOpenNode = False
if isinstance(definitionNode,(ModelBreakdown, ModelClosedDefinitionNode)) and definitionNode.parentChildOrder is not None:
view.xTopRollup = CHILD_ROLLUP_LAST if definitionNode.parentChildOrder == "children-first" else CHILD_ROLLUP_FIRST
expandDefinition(view, xTopStructuralNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
view.dataCols = xTopStructuralNode.leafNodeCount
break
elif disposition == "y" and yTopStructuralNode is None:
yTopStructuralNode = StructuralNode(None, definitionNode, view.zmostOrdCntx, breakdownTableNode=table)
yTopStructuralNode.hasOpenNode = False
if isinstance(definitionNode,(ModelBreakdown, ModelClosedDefinitionNode)) and definitionNode.parentChildOrder is not None:
view.yAxisChildrenFirst.set(definitionNode.parentChildOrder == "children-first")
view.yTopRollup = CHILD_ROLLUP_LAST if definitionNode.parentChildOrder == "children-first" else CHILD_ROLLUP_FIRST
expandDefinition(view, yTopStructuralNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
view.dataRows = yTopStructuralNode.leafNodeCount
break
elif disposition == "z" and zTopStructuralNode is None:
zTopStructuralNode = StructuralNode(None, definitionNode, breakdownTableNode=table)
zTopStructuralNode.hasOpenNode = False
expandDefinition(view, zTopStructuralNode, definitionNode, 1, disposition, facts, i, tblAxisRels)
break
view.colHdrTopRow = view.zAxisRows + 1 # need rest if combobox used (2 if view.zAxisRows else 1)
for i in range(view.rowHdrCols):
if view.rowNonAbstractHdrSpanMin[i]:
lastRowMinWidth = view.rowNonAbstractHdrSpanMin[i] - sum(view.rowHdrColWidth[i] for j in range(i, view.rowHdrCols - 1))
if lastRowMinWidth > view.rowHdrColWidth[view.rowHdrCols - 1]:
view.rowHdrColWidth[view.rowHdrCols - 1] = lastRowMinWidth
#view.rowHdrColWidth = (60,60,60,60,60,60,60,60,60,60,60,60,60,60)
# use as wraplength for all row hdr name columns 200 + fixed indent and abstract mins (not incl last name col)
view.rowHdrWrapLength = 200 + sum(view.rowHdrColWidth[i] for i in range(view.rowHdrCols - 1))
view.dataFirstRow = view.colHdrTopRow + view.colHdrRows + len(view.colHdrNonStdRoles)
view.dataFirstCol = 1 + view.rowHdrCols + len(view.rowHdrNonStdRoles)
#view.dataFirstRow = view.colHdrTopRow + view.colHdrRows + view.colHdrDocRow + view.colHdrCodeRow
#view.dataFirstCol = 1 + view.rowHdrCols + view.rowHdrDocCol + view.rowHdrCodeCol
#for i in range(view.dataFirstRow + view.dataRows):
# view.gridView.rowconfigure(i)
#for i in range(view.dataFirstCol + view.dataCols):
# view.gridView.columnconfigure(i)
view.modelTable = table
# organize hdrNonStdRoles so code (if any) is after documentation (if any)
for hdrNonStdRoles in (view.colHdrNonStdRoles, view.rowHdrNonStdRoles):
iCodeRole = -1
for i, hdrNonStdRole in enumerate(hdrNonStdRoles):
if 'code' in os.path.basename(hdrNonStdRole).lower():
iCodeRole = i
break
if iCodeRole >= 0 and len(hdrNonStdRoles) > 1 and iCodeRole < len(hdrNonStdRoles) - 1:
del hdrNonStdRoles[iCodeRole]
hdrNonStdRoles.append(hdrNonStdRole)
if view.topRollup["x"]:
view.xAxisChildrenFirst.set(view.topRollup["x"] == CHILD_ROLLUP_LAST)
if view.topRollup["y"]:
view.yAxisChildrenFirst.set(view.topRollup["y"] == CHILD_ROLLUP_LAST)
return (tblAxisRelSet, xTopStructuralNode, yTopStructuralNode, zTopStructuralNode)