コード例 #1
0
ファイル: GenericTable.py プロジェクト: zhaoxia413/STAMP
    def sort(self, Ncol, order):
        '''
		Sort table by given column number.
		'''
        if len(self.arraydata) == 0:
            return

        self.emit(QtCore.SIGNAL("layoutAboutToBeChanged()"))

        dataIsNumeric = isNumber(self.arraydata[0][Ncol])

        if dataIsNumeric:
            self.arraydata = SortTableNumericStrCol(self.arraydata, Ncol)
        else:
            self.arraydata = SortTableStrCol(self.arraydata, Ncol)

        if order == QtCore.Qt.DescendingOrder:
            self.arraydata.reverse()
        self.emit(QtCore.SIGNAL("layoutChanged()"))
コード例 #2
0
ファイル: stamp_cmd.py プロジェクト: hotdogee/stamp-cmd
            # Prepare table
            # ['Benjamini-Hochberg FDR', 'Bonferroni', 'No correction', 'Sidak', 'Storey FDR']
            print 'Sidak table:',
            groupMultCompMethodIndex = 3 # 'No correction'
            groupMultCompMethod = groupMultCompMethodOptions[groupMultCompMethodIndex]
            # run significance test
            groupStatsTest.run(test, groupSignTestType, groupConfIntervMethod, float(groupNominalCoverage), groupProfile)

            # apply multiple test correction
            groupStatsTest.results.performMultCompCorrection(multCompDict[groupMultCompMethod])
            groupStatsTest.results.setSelectedFeatures(selectedFeatures)
            groupStatsTest.results.filterFeatures(groupSignLevelFilter, groupSeqFilter, group1Filter, group2Filter, groupParentSeqFilter, groupParentGroup1Filter, groupParentGroup2Filter, groupEffectSizeMeasure1, groupMinEffectSize1, effectSizeOperator, groupMinEffectSize2, groupMinEffectSize2)
            
            tableData, tableHeadings = groupStatsTest.results.tableData(False)
            tableData = SortTableStrCol(tableData, 0)
            
            filename = os.path.join(saveFolder, saveTableTemplate.format(g1=groupName1, g2=groupName2))
            print '"{0}"'.format(filename),
            fout = open(filename, 'w')
            for heading in tableHeadings:
                fout.write(heading + '\t')
            fout.write('\n')
            for row in tableData:
                for entry in row:
                    fout.write(str(entry) + '\t')
                fout.write('\n')
            fout.close()
            print 'DONE.'
        else:
            print 'No Active Data, SKIP.'