2015年6月22日 星期一

Excel show all comments in worksheet

This Excel tutorial explains how to show all comments and hide all comments in workbook.


Excel show comments in worksheet


Comment is a yellow dialog box that you can write comment regarding specific Cell.


To insert a Comment, right click on a Cell and then select Insert Comment


excel_show_comments_04


When we insert a Comment into a Cell, there would be a red triangle on the top right of the Cell.


Comment is hidden by default, you need to hover the mouse over the Cell in order to display the Comment.


excel_show_comments_01


We can also show the Comment all the time. Right click on the Cell, then select Show/Hide Comments


excel_show_comments


Assume that you have many hidden comments spreading over different Cells, it is extremely difficult to locate all those comments by looking for the red triangle, especially when there are colored Cells. Even if we can locate them with eye ball, it is time consuming to hide or show all comments manually Cell by Cell.


Excel VBA show all comments in worksheet


In this section, I am going to write a Macro to show all comments in the workbook, and to facilitate testing, I have another Macro to hide all comments.


The below code is extremely short, basically I loop through all worksheets in Activeworkbook and then look for the Cells contain Comments.


Sub showComment() 
 On Error GoTo errHandler
    For Each ws In ActiveWorkbook.Sheets
        Set allCommentRng = ws.Cells.SpecialCells(xlCellTypeComments)
        For Each Rng In allCommentRng
            Rng.Comment.Visible = True
        Next
    Next
errHandler: Exit Sub
End Sub

Sub hideComment()
 On Error GoTo errHandler
    For Each ws In ActiveWorkbook.Sheets
        Set allCommentRng = ws.Cells.SpecialCells(xlCellTypeComments)
        For Each Rng In allCommentRng
            Rng.Comment.Visible = False
        Next
    Next
errHandler: Exit Sub
End Sub

Example –  show all comments in worksheet


In the below example, we have Sheet1 and Sheet2 with hidden Comment.


excel_show_comments_03


After you run the Macro, all Comment become visible


excel_show_comments_02


 


Outbound References


http://www.excelforum.com/excel-formulas-and-functions/493625-macro-delete-comments-what-if-theres-none.html


 


 



Excel show all comments in worksheet

2015年6月21日 星期日

Writing your first Excel Macro by recording Macro

This Excel tutorial guides you to create your first Excel Macro by Record Macro function, and explain how to modify Macro in Visual Basic Editor


You may also want to read:


Create Excel Add-in and add in Ribbon


Excel Record Macro


Writing your first Excel Macro by recording Macro, why?


First of all, you should face the fact that you cannot know everything. You can use Microsoft Windows does not mean you can write your own Windows. Even if you are a Windows Administrator, it only means you have better knowledge on modifying parameters, but you do not need to how to write a Windows. Similarly, you can use Photoshop does not mean you can write the software. Depending on the role, different people are required different skill set, there are people who are “users”, some are “administrators”, and some are “developers”.


If you are a starter in Excel VBA, your role is changed from a “user” to a “developer”. It is a big change, you have to understand Excel well enough to make that change, and it takes a lot of efforts even if you are an expert user. During the transition, you should try being an “administrator”, someone who knows the software well and is able to modify parameters. Even as a developer, you don’t always need to write a program from zero, you just need to pull different sets of code together to become your own work.


As an administrator, you may not understand every line of code of a program but you should be able to change the parameters. Therefore, the first step of understanding Excel VBA is to record a Macro, read a program’s code and practice modifying the code and see what happens through trials and errors.


Understanding recorded Macro


Before continuing reading, you should have knowledge in recording Macro. Read the below article if you do not know how.


Excel Record Macro


Once you know the Excel VBA code behind an action, you can write your own actions or modify the code for your own need.


For example, you have recorded actions that do the followings


1) Select worksheet “Sheet1″

2) Type “1” in Range A1

3) Delete value in Range A1


Having recorded the above actions, go to VB Editor (Alt+F11) to see how the codes look like for each of those actions


1   Sub Macro1()
2      Sheets("Sheet1").Select
3      Range("A1").Select
4      ActiveCell.FormulaR1C1 = "1"
5      Range("A1").Select
6      Selection.ClearContents
7    End Sub

You can easily identify which line of code is representing the corresponding action. Now I am translating each code below into English.


1    Create a Macro called Macro1 with no parameters

2   Select worksheet “Sheet1″

3   Select Range A1

4   For the active cell (the one you have just selected), type formula  “1”

5   Select Range A1

6   For the selected Range, clear the contents

7   End of the Macro


It isn’t so hard to understand, right? Some codes are very easy to read, such as “Select”, “Range”, “Sheets”. If you don’t understand any of the code, just search it in goggle. For example, if you don’t understand what is FormulaR1C1, just search “Excel VBA FormulaR1C1″, and you will get a lot of results.


Writing your first Excel Macro


Now that you have identified the underlying code behind each action, you should be capable of writing your own first Excel Macro.


For example, I want to write “2” in A1 of “Sheet2″


1   Sub Macro2()      'change a different name for each Macro
2      Sheets("Sheet2").Select
3      Range("A1").Select
4      ActiveCell.FormulaR1C1 = "2"
5    End Sub

You have created your first VBA by modifying a recorded Macro, it is a good start! Try different actions like changing cell color, copy and paste, creating pivot table, search a text, and see how the codes look like, I assure you they are very easy and straight forward to use.


What’s Next?


There are things that cannot be recorded, but you should learn them step by step. The next thing you need to learn is the programming basics, such as define variables, VBA function, Objects and their Properties, condition (such as If..Else), Loop (such as For…Next)


You are recommended to read my other posts under the Excel VBA category in order of Unit.


Outbound References


https://www.youtube.com/watch?v=MYNVaRnZRgY


 



Writing your first Excel Macro by recording Macro

Excel verify Number data type and convert Text to Number

This Excel tutorial explains how to verify if a column contains only Number data type. If it is a Text then convert Text to Number.


Excel verify Number data type


Number can be in two forms in Excel – Text and Number. If a Number is a Text, there is a small triangle on the top left of the Cell.


By default, number in Text format aligns to the left while Number aligns to the right, but you can change the alignment.


convert_text_to_number


There are three kinds of data in Excel – Date, Number and Text


To check whether the data is number, we have to make sure it is not Text and Date.


To make sure it is not a Text, Use IsNumer Function. IsNumber returns TRUE for Date and Number.


To make sure it is not  Date, use IsDate Function, Number is not considered as Date. Unfortunately, IsDate is for VBA only, we need to workaround with Cell Function for worksheet.


If the format is Date, Cell Function returns a value from D1 to D9, depending on the date format.


Now to combine IsNumber and Cell Function,


=IF(ISNUMBER(A2),IF(LEFT(CELL("Format",A2),1)="D",TRUE,FALSE))

convert_text_to_number_04


Convert Text to Number


convert_text_to_number_02


To convert Text to Number,select B2:B4, and then find the exclamation mark in B2, select “Convert to Number”.


Mass verification of Number data type (VBA)


Assume that you have hundreds of rows and columns with different required format, how should you check the data type?


First of all, create a row (row 1 in the example) that specifies the required data type for each column.


convert_text_to_number_05


Now we can create a Macro that loops through row 1. If the required format is “Number”, then check  the data of the whole column whether it is a Text. The yellow Cells are in incorrect format that we want to identify in a new worksheet called “is not number”.


Public Sub isNotNumber()
On Error GoTo errHandler
    Set dataTypeRng = Application.InputBox("Input data Type Range", Type:=8)
    dataBeginRow = Application.InputBox("Input data begin row")
    dataEndRow = Application.InputBox("Input data end row")
    
    For Each Rng In dataTypeRng
        If Rng.Value = "Number" Then
            col_letter = Split(Rng.Address, "$")(1)
            For Each rng2 In Range(col_letter & dataBeginRow & ":" & col_letter & dataEndRow)
                If Not IsEmpty(rng2) And IsDate(rng2) Then
                    txt = txt & Replace(rng2.Address, "$", "") & " (Date)" & Chr(10)
                ElseIf Not IsEmpty(rng2) And Not Application.WorksheetFunction.IsNumber(rng2) Then
                    txt = txt & Replace(rng2.Address, "$", "") & " (Text)" & Chr(10)
                End If
            Next rng2
        End If
    Next Rng

    If txt <> "" Then
        For Each ws In ActiveWorkbook.Worksheets
            If Not wsExists("is not number") Then
                Set newWS = ThisWorkbook.Worksheets.Add
                newWS.Name = "is not number"
            End If
        Next ws
        Sheets("is not number").Select
        Sheets("is not number").Range("A1").Value = txt
    Else: MsgBox ("All Number format are correct")
   End If
    
errHandler: Exit Sub
End Sub

Function wsExists(wksName As String) As Boolean
    On Error Resume Next
    wsExists = CBool(Len(Worksheets(wksName).Name) > 0)
    On Error GoTo 0
End Function

Demonstration- Identify non-Number Cell


convert_text_to_number_05


Run Macro


Type in the data Type Range


convert_text_to_number_06


Type in the data being row


convert_text_to_number_07


Type in the data end row


convert_text_to_number_08


A worksheet called “is not number” is created, with the incorrect type inside the brackets. If you want to display them in A1, A2, A3… just copy the values to Notepad and then copy and paste back into Excel. I don’t want to create a Macro to correct the format because I think it is necessary to read Cell by Cell to understand what is causing the mistakes.


convert_text_to_number_09


 


 



Excel verify Number data type and convert Text to Number

2015年6月20日 星期六

Excel VBA Msgbox and handling of return value

This Excel tutorial explains how to use Excel VBA Msgbox with carriage return such as vbCr, vbNewLine, and handling of return value such as vbOK, vbCancel, vbRetry


You may also want to read:


Excel VBA Inputbox and Application.Inputbox


What is Excel VBA MsgBox?


Excel VBA MsgBox is a prompt box that is used to prompt user for important information, usually provide user with OK and Cancel buttons. Note that there is another prompt box called InputBox which receives text input from user but it is not in the scope of this article.


Why do you need Excel VBA MsgBox?


There are several reasons that you may need Excel VBA Msgbox:


1) When you run a Sub or a Function, you will see the final result only and the result may not be what you expect while there is no error message. In that case, you can insert a Msgbox code within a Procedure to check the value of a variable at specific line of code.


2) To warn user or confirm an action, such as asking users if they confirm to delete data


Syntax of Excel VBA MsgBox


MsgBox(prompt[, buttons] [, title] [, helpfile, context])











PromptRequired. String expression displayed as the message in the dialog box. The maximum length of Prompt is approximately 1024 characters, depending on the width of the characters used. If Prompt consists of more than one line, you can separate the lines using1) carriage return – Chr(13) or vbCr OR
2) line feed – Chr(10) or vbLf OR3) carriage return + line feed – Chr(13)& Chr(10) or vbCrLf  OR4) vbNewLine, suitable for different platforms
ButtonsOptional. Numeric expression that is the sum of values specifying the number and type of buttons to display, the icon style to use, the identity of the default button, and the modality of the message box. You can add more than one Buttons using + sign, such as vbOKCancel + vbExclamationmsgbox_02

If you omit Buttons, the default value is zero (The user must respond to the message box before continuing work in the current application.)If you choose a Button, you need to define a variable to return a value, otherwise you will receive the following error message.msgbox_07


The return values are as follows


















Return ValueValue
vbOK1
vbCancel2
vbAbort3
vbRetry4
vbIgnore5
vbYes6
vbNo7

 

TitleOptional. String expression displayed in the title bar of the dialog box.msgbox_01

If you omit Title, the application name (Microsoft Excel) is placed in the title bar.

 helpfile Optional. String expression that identifies the Help file to use to provide context-sensitive Help for the dialog box. If helpfile is provided, context must also be provided.
 context Optional. Numeric expression that is the Help context number assigned to the appropriate Help topic by the Help author. If context is provided, helpfile must also be provided.

 


































































Buttons Argument (blue is about Modality)
MemberValueDescription
vbAbortRetryIgnore2Display Abort, Retry, and Ignore buttons.
vbApplicationModal0The user must respond to the message box before continuing work in the current application.
vbCritical16Display Critical Message icon.
vbDefaultButton10First button is default.
vbDefaultButton2256Second button is default.
vbDefaultButton3512Third button is default.
vbDefaultButton4768Fourth button is default.
vbExclamation48Display Warning Message icon.
vbInformation64Display Information Message icon.
vbMsgBoxHelpButton16384Adds a Help button to the message box
vbMsgBoxRight524288Text is right aligned
vbMsgBoxRtlReading1048576Specifies text should appear as right-to-left reading on Hebrew and Arabic systems
vbMsgBoxSetForeground65536Specifies the message box window as the foreground window
vbOKCancel1Display OK and Cancel buttons.
vbOKOnly0Display OK button only (this is the default).
vbQuestion32Display Warning Query icon.
vbRetryCancel5Display Retry and Cancel buttons.
vbSystemModal4096System modal; all applications are suspended until the user responds to the message box
vbYesNo4Display Yes and No buttons.
vbYesNoCancel3Display Yes, No, and Cancel buttons.

Example of Excel VBA MsgBox


Step 1 – MsgBox with two lines of message


Public Sub test1()
    sInput = MsgBox("Are you sure to delete the data?" & vbNewLine & "Data will be deleted permanently")
End Sub

msgbox_03


Step 2 – Add OK / Cancel Button


Public Sub test2()
    sInput = MsgBox("Are you sure to delete the data?" & vbNewLine & "Data will be deleted permanently", vbOKCancel)
End Sub

msgbox_04


Step 3 – Add exclamation logo


 Public Sub test3()
    sInput = MsgBox("Are you sure to delete the data?" & vbNewLine & "Data will be deleted permanently", vbOKCancel + vbExclamation)
End Sub

msgbox_05


Step 4 – Add message box title


Public Sub test4()
    sInput = MsgBox("Are you sure to delete the data?" & vbNewLine & "Data will be deleted permanently", vbOKCancel + vbExclamation, "Warning")
End Sub

msgbox_06


Step 5 – Condition on return value


Public Sub test5()

sinput = MsgBox(“Are you sure to delete the data?” & vbNewLine & “Data will be deleted permanently”, vbOKCancel + vbExclamation, “Warning”)
    If sinput = vbOK Then
        ‘delete something
    ElseIf sinput = vbCancel Then
        ‘no action
    End If

End Sub


In the above example, we have OK and Cancel Buttons in MsgBox. If you click on the red cross on the top right, the return value is same as clicking on Cancel Button.


If your MsgBox contains only 1 button, clicking on the red cross is same as clicking on the only button, therefore red cross doesn’t necessarily mean Cancel.


 Outbound References


https://msdn.microsoft.com/en-us/library/office/gg251821%28v=office.15%29.aspx



Excel VBA Msgbox and handling of return value

Excel VBA Inputbox and Application.Inputbox

This Excel tutorial explains difference between VBA Inputbox and  Application.Inputbox and how to use them.


You may also want to read:


Excel VBA Msgbox and handling of return value


Excel VBA Inputbox and Application.Inputbox


Inputbox is pop up dialog box that displays a message and provides a text box for users to input free text. It is very similar to Msgbox except that Msgbox does not have a text box for user input.


There are two kinds of Inputbox: Inputbox and Application.Inputbox. Application.InputBox allows selective validation of the user’s input, and it can be used with Microsoft Excel objects, error values, and formulas. Note that Application.InputBox calls the InputBox method; InputBox with no object qualifier calls the InputBox function.


Syntax of Inputbox (Function)


InputBox(Prompt, [Title], [Default], [Left], [Top], [HelpFile], [HelpContextID])






















PromptRequiredThe message to be displayed in the dialog box. If prompt consists of more than one line, you can separate the lines using a carriage return character (Chr(13)), a linefeed character (Chr(10)), or carriage return–linefeed character combination (Chr(13) & Chr(10)) between each line.
TitleOptionalThe title for the input box. If this argument is omitted, the application name is placed in the title bar.
DefaultOptionalString expression displayed in the text box as the default response if no other input is provided. If you omit default, the text box is displayed empty.
LeftOptionalSpecifies an x position for the dialog box in relation to the upper-left corner of the screen, in points.If omitted, the dialog box is horizontally centered.
TopOptionalSpecifies a y position for the dialog box in relation to the upper-left corner of the screen, in points. If omitted, the dialog box is vertically positioned approximately one-third of the way down the screen.
HelpFileOptionalThe name of the Help file for this input box. If the HelpFile and HelpContextID arguments are present, a Help button will appear in the dialog box.
HelpContextIDOptionalThe context ID number of the Help topic in HelpFile.

Example of Inputbox (Function)


The below example demonstrates how to create an input box for users to input their names, and then use the name in MsgBox.


Note that if user press Cancel button, use sinput = “” to capture.


 Public Sub inputFunction()
    sinput = InputBox("Please input your name", "User Input", "default value")
    If sinput = "" Then
        Exit Sub
    Else
        MsgBox ("Your name is " & sinput)
    End If
End Sub

 excel_inputbox


When OK button is pressed


excel_inputbox_02


Syntax of Application.Inputbox (Method)


Application.InputBox(Prompt, [Title], [Default], [Left], [Top], [HelpFile], [HelpContextID], [Type])


























PromptRequiredThe message to be displayed in the dialog box. If prompt consists of more than one line, you can separate the lines using a carriage return character (Chr(13)), a linefeed character (Chr(10)), or carriage return–linefeed character combination (Chr(13) & Chr(10)) between each line.
TitleOptionalThe title for the input box. If this argument is omitted, the default title is “Input.”
DefaultOptionalSpecifies a value that will appear in the text box when the dialog box is initially displayed. If this argument is omitted, the text box is left empty. This value can be a Range object.
LeftOptionalSpecifies an x position for the dialog box in relation to the upper-left corner of the screen, in points.If omitted, the dialog box is horizontally centered.
TopOptionalSpecifies a y position for the dialog box in relation to the upper-left corner of the screen, in points. If omitted, the dialog box is vertically positioned approximately one-third of the way down the screen.
HelpFileOptionalThe name of the Help file for this input box. If the HelpFile and HelpContextID arguments are present, a Help button will appear in the dialog box.
HelpContextIDOptionalThe context ID number of the Help topic in HelpFile.
TypeOptionalSpecifies the return data type. If this argument is omitted, the dialog box returns text.
















ValueDescription
0A formula
1A number
2Text (a string)
4A logical value (True or False)
8A cell reference, as a Range object
16An error value, such as #N/A
64An array of values

As you can see, Application.Inputbox has one more argument “Type” which could perform validation.


Example of Application.Inputbox (Method)


The below example demonstrates how to create an input box for users to input their names, and then use the name in MsgBox.


You should use sinput = False to prevent error when users click on Cancel Button.


 Public Sub inputMethof()
    sinput = Application.InputBox("Please input your name", "User Input", "default value")
    If sinput = False Then
        Exit Sub
    Else
        MsgBox ("Your name is " & sinput)
    End If
End Sub

You may set the Range using Type:=8 in the last argument. In this case, you should use On Error to prevent error from pressing Cancel Button as well as setting value as Range.


Public Sub inputRanged()
On Error GoTo errHandler:
    Set rng = Application.InputBox("Please input data Range", "User Input", Type:=8)
    rng.Interior.ColorIndex = 19
errHandler: Exit Sub
End Sub

If you enter a value that is not correct (not a Range), an error message will pop up and then return you to the Inputbox. This is how the validation of data type is done with Application.Inputbox, such checking applies to other formats as well.


excel_inputbox_03


If you does not like the message from validation to pop up, turn it off with


Application.DisplayAlerts = False

Outbound References


https://msdn.microsoft.com/en-us/library/office/ff839468.aspx


https://msdn.microsoft.com/en-us/library/office/gg251811.aspx



Excel VBA Inputbox and Application.Inputbox

2015年6月14日 星期日

Create Excel Add-in and add in Ribbon

This Excel tutorial explains how to add Excel Add-in in Ribbon.


Why use Excel Add-in


After you have created a Macro (Sub Procedure), you may want to distribute it for users to use. You can simply add the VBA code in the Module of a Workbook and then distribute the Workbook, but the problem is that the Macro cannot be used in other Workbook.


Depending on the situation, you may want to distribute a Macro is through Add-in. Add-in is a file with extension .xla (for Excel 2003 and older version) and .xlam (for Excel 2007 and newer version) where users can use the Macro in any Workbook in his workstation. The Add-in itself is stored in the local drive of the receiver, it is not stored in a Workbook. If you have used Functions from Analysis ToolPak before, you realize that if you send the Workbook that used the Function (such as MRound, Networkdays) to others who do not have the Add-in, the formula will fail once refreshed.


To summarize, if your Macro is only for use in particular Workbook, you don’t have to use Add-in. If not, create an Add-in.


After creating an Excel Add-in, send the Add-in to users, then install the add-in.


In order to facilitate users to locate and run the Macro, I highly recommend to add the Macro in Ribbon.


In the following demonstration, I will use a real example where I create several Macro for users to validate data, such as data formatting and conflicting values.


Create Excel Add-in


Assume that you have already created several Sub Procedure in the Module of a Workbook. The next step is to tell Excel to create a ribbon.


In VBE (Alt+F11), double click on ThisWorkBook under VBA Project of the Add-In, we need to add two Events here:


Workbook.AddinInstall Event – Triggered when users install the Add-in. We are going to tell Excel to add ribbon here.


Workbook.AddinUninstall Event – Triggered when users uninstall the Add-in. We are going to tell Excel to remove ribbon here.


Insert the following code in ThisWorkbook


Private Sub Workbook_AddinInstall()
    With Application.CommandBars("Formatting").Controls.Add
        .Caption = "Identify incorrect Date format" 'The button caption
        .Style = msoButtonCaption
        .OnAction = "checkDateText" 'The Macro name you want to trigger
    End With
End Sub

Private Sub Workbook_AddinUninstall()
On Error Resume Next
    Application.CommandBars("Formatting").Controls("Identify incorrect Date format").Delete
On Error GoTo 0
End Sub

The above code adds a button called Identify incorrect Date format. If you want to add more, copy the code and change the Caption and OnAction parameters.


Save Excel Add-In


Save the Workbook as you would normally save it, except that you save it as xlam file type for Add-In. Name the file as checking P2 template.


create_excel_add_in


The xlam file icon looks like Excel, you can send this file for users to install.


create_excel_add_in_01


After you have saved the file as .xlam, all worksheets are hidden.


To change it back to a normal worksheet, change the IsAddin Property of ThisWorkbook to False.


create_excel_add_in_02


Install Excel Add-in (User)


Navigate to Developer tab > Add-Ins, browse the Add-In location to add.


create_excel_add_in_03


Now a tab called ADD-INS is added, under which is the button “Identify incorrect Date format”


create_excel_add_in_04


If you have many items, you can group items by different CommandBars as below.


create_excel_add_in_05


In the above example, I grouped them by Formatting / Worksheet Menu Bar


    With Application.CommandBars("Formatting").Controls.Add
        .Caption = "Remove Space in prefix/suffix"
        .Style = msoButtonCaption
        .OnAction = "checkSpace"
    End With
        
    With Application.CommandBars("Worksheet Menu Bar").Controls.Add
        .Caption = "Identify incorrect Original Hire Date"
        .Style = msoButtonCaption
        .OnAction = "chk_Original_Hire_Dt"
    End With

http://sitestory.dk/excel_vba/my_menu.htm



Create Excel Add-in and add in Ribbon