Valnurat

How do you convert date dd/mm/yyyy

8 posts in this topic

#1 ·  Posted (edited)

Hi experts.

I'm sorry if this has been explained before.

I have a list of dates. Some are like this: YYYY/MM/DD and that is ok. But then I have some like this: DD/MM/YYYY and that is not ok.

I want to go through the list in convert it to YYYY/MM/DD.

How do you convert DD/MM/YYYY to YYYY/MM/DD?

Edited by Valnurat

Yours sincerely

Kenneth.

Share this post


Link to post
Share on other sites



#3 ·  Posted

ok. Will look into it.

I have another thought.

If you have a mixed list of date like YYYY/MM/DD, DD/MM/YYYY and MM/YYYY/DD or any kind of mixed dates.

How do you convert it to YYYY/MM/DD?


Yours sincerely

Kenneth.

Share this post


Link to post
Share on other sites

#4 ·  Posted (edited)

mmm, 4the YYYY is easy with StringLen, but the limit is when MM <= 12 and DD <= 12... because you don't have a way to understand if is a MM or DD, the first 12 is the limit after 12 is DD because the MM limit is 12. At the moment I don't have any idea.

:'(

 

 

Edited by rootx

Share this post


Link to post
Share on other sites

#5 ·  Posted (edited)

@Valnurat
Something like this :)

 

#include <MsgBoxConstants.au3>
#include <StringConstants.au3>

Local $aDateTimes[3] = ["17/03/2017", "2017/03/17", "03/2017/17"]
Local $aDateTimesSplitted
For $i = 0 To UBound($aDateTimes) - 1
    $aDateTimesSplitted = StringSplit($aDateTimes[$i], "/", $STR_NOCOUNT)
    If($aDateTimesSplitted[0] > 12 And $aDateTimesSplitted[0] <= 31 And $aDateTimesSplitted[1] <= 12) Then ; DD/MM/YYYY
        MsgBox($MB_ICONINFORMATION, "Date format:", "Old date format: " & $aDateTimes[$i] & @CRLF & "New date format: " & $aDateTimesSplitted[2] & "/" & _
                                                                                                                          $aDateTimesSplitted[1] & "/" & _
                                                                                                                          $aDateTimesSplitted[0])
    ElseIf($aDateTimesSplitted[0] <= 12 And $aDateTimesSplitted[1] > 31) Then ; MM/YYYY/DD
        MsgBox($MB_ICONINFORMATION, "Date format:", "Old date format: " & $aDateTimes[$i] & @CRLF & "New date format: " & $aDateTimesSplitted[1] & "/" & _
                                                                                                                          $aDateTimesSplitted[0] & "/" & _
                                                                                                                          $aDateTimesSplitted[2])
    Else
        MsgBox($MB_ICONINFORMATION, "Date format:", "Date format: " & $aDateTimes[$i])
    EndIf
Next

Where you find $aDateTimes, you could find a function that read lines and then, paste the new line as I do in the MsgBox...
This is just an example...
Tell me if this script works correctly in your specific case :)
 

Edited by FrancescoDiMuro

Click here to see my signature:

Spoiler

I will always thank you for the time you spent for me.
I'm here to ask, and from your response, I'd like to learn.
By my knowledge, I can help someone else, and "that someone" could help in turn another, and so on.

Share this post


Link to post
Share on other sites

#6 ·  Posted

Making that simpler:

Local $aDateTimes[3] = ["17/03/2017", "2017/03/17", "03/2017/17"]

For $i = 0 To UBound($aDateTimes) - 1
    $aDateTimes[$i] = StringRegExpReplace($aDateTimes[$i], "(\d\d)/(\d\d)/(\d\d\d\d)", "$3/$2/$1")  ; deals with DD/MM/YYYY
    $aDateTimes[$i] = StringRegExpReplace($aDateTimes[$i], "(\d\d)/(\d\d\d\d)/(\d\d)", "$2/$1/$3")  ; deals with MM/YYYY/DD
    ; there is NO way to deal with [unmanageable] US-style dates MM/DD/YYYY for DD < 13
Next
_ArrayDisplay($aDateTimes)

 


This wonderful site allows debugging and testing regular expressions (many flavors available). An absolute must have in your bookmarks.
Another excellent RegExp tutorial. Don't forget downloading your copy of up-to-date pcretest.exe and pcregrep.exe here
RegExp tutorial: enough to get started
PCRE v8.33 regexp documentation latest available release and currently implemented in AutoIt beta.

SQLitespeed is another feature-rich premier SQLite manager (includes import/export). Well worth a try.
SQLite Expert (freeware Personal Edition or payware Pro version) is a very useful SQLite database manager.
An excellent eBook covering almost every aspect of SQLite3: a must-read for anyone doing serious work.
SQL tutorial (covers "generic" SQL, but most of it applies to SQLite as well)
A work-in-progress SQLite3 tutorial. Don't miss other LxyzTHW pages!
SQLite official website with full documentation (may be newer than the SQLite library that comes standard with AutoIt)

Share this post


Link to post
Share on other sites

#7 ·  Posted


Signature beginning:   Wondering who uses AutoIT and what it can be used for ?
* GHAPI UDF - modest begining - comunication with GitHub REST API *
ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API *

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 - BETA * ADO.au3 UDF SMTP Mailer UDF *

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Best coding practices * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * 

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2017-06-04

Share this post


Link to post
Share on other sites

#8 ·  Posted (edited)

A way that can be valid is to parameterize the position of the year in the position within it stringsplit

DD MM YYYY     YYYY MM DD      MM YYYY DD
["11/11/2017",  "2017/11/11",   "11/2017/11"]

postion YYYY[2] postion YYYY[0] postion YYYY[1]

firts target is find the 4char value in the result of StringSplit then isolate the YYYY

in the loop you can tell if the position YYYY = 2 ... then DD MM YYYY etc...

Edited by rootx

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!


Register a new account

Sign in

Already have an account? Sign in here.


Sign In Now

  • Similar Content

    • sree161
      By sree161
      Hi,
      i have a code which generates two numeric outputs.i have to save them in excel.
      Is there any way to export them to specific cells in excel???
    • TotalAuto
      By TotalAuto
      Howdy All
      I've gone around and around in circles wasting hours trying to fix this problem to no avail so I thought I would try posting for help given there are some real smart people in this forum.
      Background
      I have 5 separate .au3 scripts that all do different basic tasks. For example:
      1.au3 = opens Chrome browser to obtain information from a specific website then closes
      2.au3 = opens an Excel workbook to run a macro then saves and closes
      3.au3 = Open two seperate workbooks and transfers data from one to the other then saves and closes
      4.au3 = .......etc
      5.au3 = .......etc
      These 5 separate scripts, doing completely different tasks, need to each run once per day at 5 different designated times within a day and then close. For example:
      1.au3 = 10am
      2.au3 = 12pm
      3.au3 = 2pm
      4.au3 = 4pm
      5.au3 = 5pm
      Problem
      I can not get these different scripts to reliably run at their designated times. When I manually run these scripts individually by using 'Go F5' they work perfectly. If I convert these scripts to an .exe and manually run each one they work about 98% of time.
      How can I schedule these different .au3 files or associated .exe files to reliably run each day at different times?
      Attempts To Fix The Issue
      1. I have tried converting each .au3 script into their own .exe file and use Window's Task Scheduler to run these .exe files at their designated time but the success rate  of running each .exe in full, to completion, without error is very low at about 30%. Things that commonly go wrong include a browser not opening but movement still continues on the desk top. Other times things just do not happen at all.
      2. I have Windows 7 64 bit and have tried creating and running both (x86) and (x64) .exe files but again reliability problems exist;
      3. I have also tried moving each .exe file to the My Documents folder as I read someone that keeping your files on your desktop ties your files to individual Windows user profiles which can cause AutoIt operating errors. Not sure if this is correct but thought I would try it anyway. It did not fix my issue.
      4. I installed a program called AlwaysUp which supposedly always reliably runs in the background and will reliably execute your AutoIt script or .exe files. Still have significant reliability issues.
      Therefore, can someone please provide advice on how I can get my 5 different .au3 files to run at 5 designated times through the day, every day, without fail? Overtime I will be creating more and more different .au3 files to run certain tasks throughout the day and do not want to create one large AutoIt file that continually runs and attempts to do all the different tasks itself.
      Any help is very appreciated.
      Thanks
      Dan
       
       
    • hugomito
      By hugomito
      Hi all,
      I built an AutoIt application that interacts with several other applications/software. Now, it's turn to interfact with Visual Studio Team Services (VSTS).
      Does anyone has a blog, demo, script to share?
      Thanks!
    • Viki
      By Viki
      This is my first time here so please dont bombard me that what a silly question I am asking!!
      I have 500 rows (A1:A500) in a spreadsheet and I just want to copy one by one row and then paste into another application and then press enter, loop should repeat this until finishes all 500 rows.
      I have looked at clipget(), clip(put() but dont know how to select next row in next turn. I also looked at Array to store but again no luck. Can some guide me please..
    • DineshPawar
      By DineshPawar
      0down votefavorite   In my current project, Excel macro open AutoIt script using a function Call Shell("location of autoit script").
      For proper functioning of AutoIt script it's need to be close parent Excel workbook, so this closing Excel action is written in AutoIt script itself.
      But as soon as AutoIt script close parent Excel workbook then script get pause and it do nothing.
      How open the AutoIt script from Excel workbook and after that parent Workbook get close?