excel vba convert text yyyymmdd to date with code examples

Excel is a powerful program commonly used in offices and businesses for data analysis and processing. It is often necessary to convert dates in a specific format, such as yyyymmdd, into a recognizable date format in Excel. This conversion can be time-consuming if done manually, but with the use of Visual Basic for Applications (VBA), it can be automated. In this article, we will explore how to convert text yyyymmdd to date format using Excel VBA.

What Is VBA?

Visual Basic for Applications (VBA) is a programming language that is built into Excel and other Microsoft Office applications. It can be used to automate repetitive tasks, such as data processing and analysis. With VBA, you can create macros to perform operations on data that would be difficult, if not impossible, to do manually.

What Is the yyyymmdd Date Format?

The yyyymmdd date format is a particular format used to represent dates, where y represents the year, m represents the month, and d represents the day. For example, if the date is January 1, 2022, the yyyymmdd format will be represented as 20220101.

How to Convert Text yyyymmdd to Date Format in Excel VBA

Now that we have an understanding of Visual Basic for Applications (VBA) and the yyyymmdd format, let's explore how to convert it to date format in Excel using VBA.

Step 1: Open the VBA Editor

To get started, open the VBA Editor in Excel. You can do this by going to the Developer tab, which is hidden by default. To enable it, go to File > Options > Customize Ribbon and check the box next to Developer.

Once you have enabled the Developer tab, click on it and then select the Visual Basic option. This will launch the VBA Editor.

Step 2: Insert a Module

In the VBA Editor, insert a new module by going to Insert > Module. This module will hold the code that will convert the yyyymmdd format into date format.

Step 3: Write the VBA Code

The next step is to write the VBA code. The code will use the VBA function CDate() to convert the text to date format.

Here is an example of the VBA code that can be used to convert the yyyymmdd format to date format:

Sub ConvertToDateFormat()
Dim i As Long
Dim cell As Range

For Each cell In Selection
i = cell.Value
cell.Value = CDate(Left(i, 4) & "/" & Mid(i, 5, 2) & "/" & Right(i, 2))
cell.NumberFormat = "mm/dd/yyyy"
Next cell
End Sub

In this code, we start by declaring two variables: i and cell. We then use a For Each loop to iterate through each selected cell. The value of the selected cell is stored in the variable i. The CDate() function is then used to convert the text to date format. The date is constructed by concatenating the year, month, and day using the Left(), Mid(), and Right() functions. The resulting date is then set as the value of the cell.

Finally, we format the cell with the desired date format using the NumberFormat property. In this case, we are formatting the date in mm/dd/yyyy format.

Step 4: Test the Code

Once you have written the code, save the module and run it by pressing F5 or by clicking on the Run button in the VBA Editor toolbar. Select the range of cells containing the yyyymmdd format that you want to convert to date format.

The code will convert the yyyymmdd format to date format and apply the desired formatting to the cells. You should now be able to work with the date values in Excel as a standard date format within a spreadsheet.


Converting text yyyymmdd to date format in Excel VBA can be a time-consuming process if done manually. However, VBA can automate this process and save considerable time. With the above example VBA code and the knowledge of the CDate() function, you can be confident in your ability to automate this process in Excel. By using VBA, you can streamline and automate your workflow in Excel, making it a powerful tool for data processing and analysis.

I can expand on the previous topics.

VBA in Excel:

Visual Basic for Applications (VBA) is a programming language that is built into Excel and other Microsoft Office applications. With VBA, you can write macros, customize the user interface, and automate tasks, which can save you a considerable amount of time. VBA code is executed within the application, allowing you to interact with objects such as worksheets, charts, and range objects.

Here are some examples of how VBA can be used in Excel:

  • Automating repetitive tasks, such as formatting or data cleaning
  • Creating custom functions for calculations or data analysis
  • Building custom user interfaces for specific tasks

yyyymmdd dates:

The yyyymmdd format is a specific way of representing dates using year (yyy), month (mm), and day (dd). This format is commonly used in databases and is especially helpful when sorting and searching for dates. While it is not as easy to read as other date formats (such as mm/dd/yyyy or dd/mm/yyyy), it can be easily translated into a standard date format.

Here are a few more things to keep in mind about yyyymmdd dates:

  • The format does not contain any delimiter, such as hyphens, slashes, or dots.
  • It is a fixed-length format, which means that it will have the same number of characters for every date.
  • The format is used in some countries, notably Japan and China, as the preferred way of representing dates in official documentation.

Converting yyyymmdd to date format using VBA:

Excel has built-in date functions that can parse dates in many formats, including yyyymmdd. However, it can be cumbersome to apply the date function manually, especially if you have to convert many dates. You can automate the process using VBA code, as we discussed earlier.

The code we provided earlier uses the CDate() function to convert yyyymmdd dates into a standard date format. CDate() converts a string expression into a date value. In our code, we used string concatenation to construct the date string by extracting the year, month, and day from the yyyymmdd string. This string is passed to the CDate() function, which returns a date value. Finally, we set the cell value to this date and format the cell using the NumberFormat property.

There are other ways to perform the conversion, such as using the DateSerial() function. However, the CDate() function is simple and straightforward.

In conclusion, VBA is a powerful tool that allows you to automate time-consuming tasks in Excel, and it can be used to convert yyyymmdd dates to standard date format. With VBA, you can save time, increase efficiency, and gain valuable insights from your data.

Popular questions

Here are five possible questions and answers about Excel VBA conversion of text yyyymmdd to date format:

Q: What is VBA?
A: VBA stands for Visual Basic for Applications and it is a programming language that is built into Excel and other Microsoft Office applications. It can be used to automate tasks, create macros, and customize the user interface.

Q: Why is yyyymmdd format useful?
A: The yyyymmdd format is useful because it is a fixed-length format that can be sorted and searched easily, especially in databases. It is also used in some countries for official documentation.

Q: How does the CDate() function work?
A: The CDate() function converts a string expression into a date value. It can recognize and convert date and time representations in many formats, including yyyymmdd. The resulting value is a serial number that represents the date and time.

Q: Can I use VBA to convert other date formats?
A: Yes, VBA can be used to convert other date formats as well. You can use built-in functions such as DateSerial(), DateValue(), or Format() to convert dates between various formats. The approach may depend on the original format and the desired output format.

Q: Can I apply the code to a range of cells with different formats?
A: Yes, you can apply the code to a range of cells with different formats, as long as they contain yyyymmdd date strings. The CDate() function can convert different formats as long as they are valid date strings, but you may need to adjust the code to handle different cell formatting or data validation rules.



As an experienced software engineer, I have a strong background in the financial services industry. Throughout my career, I have honed my skills in a variety of areas, including public speaking, HTML, JavaScript, leadership, and React.js. My passion for software engineering stems from a desire to create innovative solutions that make a positive impact on the world. I hold a Bachelor of Technology in IT from Sri Ramakrishna Engineering College, which has provided me with a solid foundation in software engineering principles and practices. I am constantly seeking to expand my knowledge and stay up-to-date with the latest technologies in the field. In addition to my technical skills, I am a skilled public speaker and have a talent for presenting complex ideas in a clear and engaging manner. I believe that effective communication is essential to successful software engineering, and I strive to maintain open lines of communication with my team and clients.
Posts created 2505

Leave a Reply

Your email address will not be published. Required fields are marked *

Related Posts

Begin typing your search term above and press enter to search. Press ESC to cancel.

Back To Top