Impresión condicional (Microsoft Excel)
Kirk preguntó si hay una forma de controlar condicionalmente lo que se imprime en Excel. Por ejemplo, la celda A1 contiene un valor y el valor controla exactamente lo que se imprime. Quizás si A1 contiene 1, se imprime la Hoja1; si contiene 2, se imprimen Sheet1 y Sheet2.
La única forma de hacer esto es con una macro, y hay varios enfoques que puede utilizar. Considere la siguiente macro muy simple, que simplemente usa una estructura Seleccionar caso para controlar la impresión.
Sub PrintStuff() Dim vShts As Variant vShts = Sheets(1).Range("A1") If Not IsNumeric(vShts) Then Exit Sub Else Select Case vShts Case 1 Sheets("Sheet1").PrintOut Case 2 Sheets("Sheet2").PrintOut Case 3 Sheets("Sheet1").PrintOut Sheets("Sheet2").PrintOut End Select End If End Sub
Ejecute esta macro con el valor 1, 2 o 3 en la celda A1 de la primera hoja, y la macro imprime diferentes cosas según el valor. Si el valor es 1, se imprime Sheet1; si es 2, se imprime la Hoja2; y si es 3, se imprimen tanto Sheet1 como Sheet2. Si desea que diferentes valores impriman diferentes cosas, simplemente modifique la estructura Seleccionar caso para reflejar los valores posibles y lo que debe imprimirse para cada valor.
También se puede crear un enfoque más integral. Considere agregar una «hoja de control» a su libro de trabajo. Esta hoja tendría el nombre de cada hoja de trabajo en el libro de trabajo listado en la primera columna. Si coloca un valor a la derecha del nombre de una hoja de trabajo, en la segunda columna, una macro imprimirá la hoja de trabajo correspondiente.
La siguiente macro se puede utilizar para crear la «hoja de control».
Sub CreateControlSheet() Dim i as integer On Error Resume Next 'Delete this sheet if it already exists Sheets("Control Sheet").Delete On Error GoTo 0 Sheets.Add 'Add the WhatToPrint Sheet ActiveSheet.Name = "Control Sheet" Range("A1").Select 'Label the columns ActiveCell.FormulaR1C1 = "Sheet Name" Range("B1").Select ActiveCell.FormulaR1C1 = "Print?" Cells.Select Selection.Columns.AutoFit For i = 1 To ActiveWorkbook.Sheets.Count Cells(i + 1, 1).Value = Sheets(i).Name Next End Sub
La macro primero elimina cualquier hoja de control anterior, si existe. Luego agrega una nueva hoja de trabajo llamada Hoja de control y coloca etiquetas de encabezado en las columnas A y B. Luego, enumera todas las hojas de trabajo en el libro de trabajo en la columna A.
Con la hoja de control creada, puede colocar una «X» o algún otro valor (como «Y» o 1) en la columna B junto a cada hoja de trabajo que desee imprimir. Luego, la siguiente macro examina la hoja de control e imprime cualquier hoja de trabajo que tenga una marca, cualquier marca, en la celda de la columna B.
Sub PrintSelectedSheets() Dim i as Integer i = 2 Do Until Sheets("Control Sheet").Cells(i, 1).Value = "" If Trim(Sheets("Control Sheet").Cells(i, 2).Value <> "") Then Sheets(Sheets("Control Sheet").Cells(i, 1).Value).Select ActiveWindow.SelectedSheets.PrintOut Copies:=1 End If i = i + 1 Loop End Sub
Otro método consiste en crear una macro que se ejecute justo antes de imprimir.
(Este es uno de los eventos, la impresión, que Excel le permite interceptar). La siguiente macro, agregada al objeto thisWorkbook, se ejecuta cada vez que intenta imprimir o elegir Vista previa de impresión.
Private Sub Workbook_BeforePrint(Cancel As Boolean) Dim vShts As Variant Dim iResponse As Integer Dim bPreview As Boolean On Error GoTo ErrHandler vShts = Sheets(1).Range("A1") If Not IsNumeric(vShts) Then GoTo InValidEntry ElseIf vShts < 1 Or vShts > Sheets.Count Then GoTo InValidEntry Else iResponse = MsgBox(prompt:="Do you want Print Preview?", _ Buttons:=vbYesNoCancel, Title:="Preview?") Select Case iResponse Case vbYes bPreview = True Case vbNo bPreview = False Case Else Msgbox "Canceled at User request" GoTo ExitHandler End Select Application.EnableEvents = False Sheets(vShts).PrintOut Preview:=bPreview End If ExitHandler: Application.EnableEvents = True Cancel = True Exit Sub InValidEntry: MsgBox "'" & Sheets(1).Name & "'!A1" _ & vbCrLf & "must have a number between " _ & "1 and " & Sheets.Count & vbCrLf GoTo ExitHandler ErrHandler: MsgBox Err.Description Resume ExitHandler End Sub
La macro verifica el valor en la celda A1 de la primera hoja de trabajo. Utiliza este valor para determinar qué hojas de trabajo se deben imprimir. En otras palabras, un 1 imprime la primera hoja de trabajo, un 2 imprime la segunda, un 3 imprime la tercera y así sucesivamente.
Si el valor en A1 no es un valor o si es menor que 1 o mayor que el número de hojas de trabajo en el libro de trabajo, entonces se informa al usuario que el valor es incorrecto y se sale de la macro.
Suponiendo que el valor en A1 está dentro del rango, la macro le pregunta si desea usar la Vista previa de impresión. Dependiendo de la respuesta del usuario, la macro imprime la hoja de trabajo especificada o muestra la Vista previa de impresión para esa hoja de trabajo.
_Nota: _
Si desea saber cómo usar las macros descritas en esta página (o en cualquier otra página de los sitios ExcelTips), he preparado una página especial que incluye información útil.
link: / excelribbon-ExcelTipsMacros [Haga clic aquí para abrir esa página especial en una nueva pestaña del navegador]
.
ExcelTips es su fuente de formación rentable en Microsoft Excel.
Este consejo (2372) se aplica a Microsoft Excel 97, 2000, 2002 y 2003. Puede encontrar una versión de este consejo para la interfaz de cinta de Excel (Excel 2007 y posterior) aquí:
link: / excelribbon-Conditional_Printing [Impresión condicional]
.