2016-07-22 8 views
2

Ich verstecke eine Reihe von Spalten in einer Excel-Tabelle. Ich bekomme diesen Fehler: AttributeError: can't set attribute von dieser Linie worksheet.column_dimensions['B'].visible = FalseWie kann ich Spalten in Openpyxl verstecken?

Sorry, wenn dies eine sehr einfache Frage ist. Ich habe gerade eine neue Version von Openpyxl/Pandas installiert, also muss ich jetzt meinen Code durchgehen und Änderungen an der Dokumentation der neuen Version vornehmen.

worksheet.column_dimensions['B'].visible = False 
    worksheet.column_dimensions['D'].visible = False 
    worksheet.column_dimensions['E'].visible = False 
    worksheet.column_dimensions['F'].visible = False 
    worksheet.column_dimensions['G'].visible = False 
    worksheet.column_dimensions['H'].visible = False 
    worksheet.column_dimensions['I'].visible = False 
    worksheet.column_dimensions['K'].visible = False 
    worksheet.column_dimensions['L'].visible = False 
    worksheet.column_dimensions['M'].visible = False 
    worksheet.column_dimensions['N'].visible = False 
    worksheet.column_dimensions['O'].visible = False 
    worksheet.column_dimensions['P'].visible = False 
    worksheet.column_dimensions['Q'].visible = False 
    worksheet.column_dimensions['R'].visible = False 
    worksheet.column_dimensions['S'].visible = False 
    worksheet.column_dimensions['T'].visible = False 
    worksheet.column_dimensions['U'].visible = False 
    worksheet.column_dimensions['V'].visible = False 
    worksheet.column_dimensions['W'].visible = False 
    worksheet.column_dimensions['X'].visible = False 
    worksheet.column_dimensions['Y'].visible = False 
    worksheet.column_dimensions['Z'].visible = False 
    worksheet.column_dimensions['AA'].visible = False 
    worksheet.column_dimensions['AB'].visible = False 
    worksheet.column_dimensions['AC'].visible = False 
    worksheet.column_dimensions['AD'].visible = False 
    worksheet.column_dimensions['AE'].visible = False 
    worksheet.column_dimensions['AF'].visible = False 
    worksheet.column_dimensions['AG'].visible = False 
    worksheet.column_dimensions['AH'].visible = False 
    worksheet.column_dimensions['AI'].visible = False 
    worksheet.column_dimensions['AJ'].visible = False 
    worksheet.column_dimensions['AK'].visible = False 
    worksheet.column_dimensions['AM'].visible = False 
    worksheet.column_dimensions['AN'].visible = False 
    worksheet.column_dimensions['AP'].visible = False 
    worksheet.column_dimensions['AQ'].visible = False 
    worksheet.column_dimensions['AR'].visible = False 
    worksheet.column_dimensions['AS'].visible = False 
    worksheet.column_dimensions['AT'].visible = False 
    worksheet.column_dimensions['AU'].visible = False 
    worksheet.column_dimensions['AV'].visible = False 
    worksheet.column_dimensions['AW'].visible = False 
    worksheet.column_dimensions['AX'].visible = False 
    worksheet.column_dimensions['AY'].visible = False 
    worksheet.column_dimensions['AZ'].visible = False 
    worksheet.column_dimensions['BA'].visible = False 
    worksheet.column_dimensions['BB'].visible = False 
    worksheet.column_dimensions['BC'].visible = False 
    worksheet.column_dimensions['BD'].visible = False 
    worksheet.column_dimensions['BE'].visible = False 
    worksheet.column_dimensions['BF'].visible = False 
    worksheet.column_dimensions['BH'].visible = False 
    worksheet.column_dimensions['BI'].visible = False 
    worksheet.column_dimensions['BJ'].visible = False 
    worksheet.column_dimensions['BK'].visible = False 
    worksheet.column_dimensions['BL'].visible = False 
    worksheet.column_dimensions['BM'].visible = False 
    worksheet.column_dimensions['BN'].visible = False 
    worksheet.column_dimensions['BO'].visible = False 
    worksheet.column_dimensions['BP'].visible = False 
    worksheet.column_dimensions['BQ'].visible = False 
    worksheet.column_dimensions['BR'].visible = False 
    worksheet.column_dimensions['BS'].visible = False 
    worksheet.column_dimensions['BT'].visible = False 
    worksheet.column_dimensions['BU'].visible = False 
    worksheet.column_dimensions['BV'].visible = False 
    worksheet.column_dimensions['BW'].visible = False 
    worksheet.column_dimensions['BX'].visible = False 
    worksheet.column_dimensions['BY'].visible = False 
    worksheet.column_dimensions['BZ'].visible = False 
    worksheet.column_dimensions['CA'].visible = False 
    worksheet.column_dimensions['CB'].visible = False 
    worksheet.column_dimensions['CC'].visible = False 
    worksheet.column_dimensions['CD'].visible = False 
    worksheet.column_dimensions['CE'].visible = False 
    worksheet.column_dimensions['CF'].visible = False 
    worksheet.column_dimensions['CG'].visible = False 
    worksheet.column_dimensions['CH'].visible = False 
    worksheet.column_dimensions['CI'].visible = False 
    worksheet.column_dimensions['CJ'].visible = False 
    worksheet.column_dimensions['CK'].visible = False 
    worksheet.column_dimensions['CL'].visible = False 
    worksheet.column_dimensions['CM'].visible = False 
    worksheet.column_dimensions['CN'].visible = False 
    worksheet.column_dimensions['CO'].visible = False 
    worksheet.column_dimensions['CP'].visible = False 
    worksheet.column_dimensions['CQ'].visible = False 
    worksheet.column_dimensions['CR'].visible = False 
    worksheet.column_dimensions['CS'].visible = False 
    worksheet.column_dimensions['CU'].visible = False 

Auch, wenn mir jemand sagen könnte, wenn es eine effizientere Art und Weise ist die Spalten zu verstecken, die ich dort bin sicher, wahrscheinlich ist, das wäre toll.

+2

Bitte verwenden Sie ein for loop für Ihren Code – Yegers

+0

Also würde ich alle Spalten hinzufügen, die ich möchte sich in ein Array zu verstecken und dann durch das Array zu laufen, um jedes einzelne zu verstecken? – Harrison

+1

Ja und versuchen Sie die Antwort von DeepSpace – Yegers

Antwort

7

sollten Sie setzen das hidden Attribut True:

worksheet.column_dimensions['A'].hidden= True 

Um mehr als eine Spalte zu verbergen:

for col in ['A', 'B', 'C']: 
    worksheet.column_dimensions[col].hidden= True 
+0

Scheint, dass nicht alle Spalten versteckt werden müssen, dh 'col ['C']', 'col ['AL']' Wir könnten weitere Informationen über die Logik hinter welcher Spalte zu benötigen verstecken – pwnsauce

+3

@pwnsauce Ich habe nie vorgeschlagen, dass alle Spalten ausgeblendet werden sollten. Dies liegt in der Entscheidung des OP. Ich habe ihnen nur gezeigt, wie. – DeepSpace

+0

@pwnsauce Ich glaube nicht, dass das das eigentliche Problem von OP – Yegers

2

Spalten gruppiert werden können:

ws.column_dimensions.group(start='B', end='CU', hidden=True) 
Verwandte Themen