| Quintiq file version 2.0 | 
| #parent: #root | 
| StaticMethod Download ( | 
|   MacroPlan macroPlan | 
| ) as BinaryValue | 
| { | 
|   Description: '下载财务报表数据' | 
|   TextBody: | 
|   [* | 
|      | 
|     table := selectobject( macroPlan, FinancialSalesSource.FinancialSalesReport, table, not table.IsImport() and table.IsShow() ); | 
|      | 
|     xmlDOMI := XMLDOMImplementation::Create(); | 
|     xmlDOM  := xmlDOMI.CreateDocumentFromString( '<?xml version="1.0" encoding="UTF-16"?><table><name>' + table.Name() + '</name></table>' ); | 
|      | 
|     tableElement := xmlDOM.GetElementByTagName( "table", 0 ); | 
|     //Product | 
|     productcolumnelement := xmlDOM.CreateElement( "column" ); | 
|     productnameelement   := xmlDOM.CreateElement( "name" ); | 
|     producttypeelement   := xmlDOM.CreateElement( "type" ); | 
|     productnameelement.TextContent( 'Product' ); | 
|     producttypeelement.TextContent( "String" ); | 
|     productcolumnelement.AppendChild( productnameelement ); | 
|     productcolumnelement.AppendChild( producttypeelement ); | 
|     //Unit | 
|     unitcolumnelement := xmlDOM.CreateElement( "column" ); | 
|     unitnameelement   := xmlDOM.CreateElement( "name" ); | 
|     unittypeelement   := xmlDOM.CreateElement( "type" ); | 
|     unitnameelement.TextContent( 'Unit' ); | 
|     unittypeelement.TextContent( "String" ); | 
|     unitcolumnelement.AppendChild( unitnameelement ); | 
|     unitcolumnelement.AppendChild( unittypeelement ); | 
|      | 
|     tableElement.AppendChild( productcolumnelement );  | 
|     tableElement.AppendChild( unitcolumnelement );  | 
|     traverse ( table, FinancialSalesColumn, column ) { | 
|       columnelement := xmlDOM.CreateElement( "column" ); | 
|       nameelement   := xmlDOM.CreateElement( "name" ); | 
|       typeelement   := xmlDOM.CreateElement( "type" ); | 
|       nameelement.TextContent( column.Name() ); | 
|       typeelement.TextContent( "String" ); | 
|       columnelement.AppendChild( nameelement ); | 
|       columnelement.AppendChild( typeelement ); | 
|        | 
|       cells := selectsortedset( column, FinancialSalesCell, cell, cell.FinancialSalesRow().RowNr() ); | 
|      | 
|       traverse ( cells, Elements, c ) { | 
|         if( column.Index() = 0 ){ | 
|           row := c.FinancialSalesRow(); | 
|           //Product | 
|           productcellElement := xmlDOM.CreateElement( "cell" ); | 
|           productcellElement.SetAttribute( "value", row.Name() ); | 
|           productcolumnelement.AppendChild( productcellElement ); | 
|           //Unit | 
|           unitcellElement := xmlDOM.CreateElement( "cell" ); | 
|           unitcellElement.SetAttribute( "value", row.Unit() ); | 
|           unitcolumnelement.AppendChild( unitcellElement ); | 
|         } | 
|         cellElement := xmlDOM.CreateElement( "cell" ); | 
|         cellElement.SetAttribute( "value", c.Value() );  | 
|         columnelement.AppendChild( cellElement ); | 
|       } | 
|       tableElement.AppendChild( columnelement );   | 
|     } | 
|      | 
|     xmlString := xmlDOMI.CreateSerializer().WriteToString( xmlDOM ); | 
|      | 
|     //info( xmlString ); | 
|      | 
|     tableGroupHandle := TableGroupHandle::Create( FinancialSalesReport::GetDefaultName() ); | 
|     tableHandle      := TableHandle::ImportXML( BinaryValue::Construct( xmlString ) ); | 
|     tableGroupHandle.Add( tableHandle ); | 
|      | 
|     binaryData := XLS::SaveTableGroupToBinaryData( tableGroupHandle, true ); | 
|      | 
|     return binaryData.AsBinaryValue(); | 
|   *] | 
| } |