Converting to a date format in Mule using DataWeav

2019-02-27 13:58发布

问题:

My requirement is to convert a string to a date format using DataWeave in Mule

Input string

8/30/2015  4:00:13 PM

Output date needs to be in MM/DD/YYYY format i.e,

08/30/2015 

i have tried using the below logic

(($[1] splitBy " ")[0]) as :date{format:"[m01]/[d01]/[y0001]"} 

this gave the error

Exception while executing: 
"Order Date":(($[1] splitBy " ")[0]) as :date{format:"[m01]/[d01]/[y0001]"},
 Cannot coerce a :string to a :date                                                                                                                                                          ^

I am using Mule Anypoint Studio Version: 5.2.0

回答1:

First you need to convert it to a localdatetime (no timezone) and then to a string with the desired format.

"8/30/2015 4:00:13 PM" 
    as :localdatetime {format: "M/dd/yyyy h:mm:ss a"}
    as :string {format: "MM/dd/yyyy"}

For additional info see. https://docs.oracle.com/javase/8/docs/api/java/time/format/DateTimeFormatter.html

All letters 'A' to 'Z' and 'a' to 'z' are reserved as pattern letters. The following pattern letters are defined:

  Symbol  Meaning                     Presentation      Examples
  ------  -------                     ------------      -------
   G       era                         text              AD; Anno Domini; A
   u       year                        year              2004; 04
   y       year-of-era                 year              2004; 04
   D       day-of-year                 number            189
   M/L     month-of-year               number/text       7; 07; Jul; July; J
   d       day-of-month                number            10

   Q/q     quarter-of-year             number/text       3; 03; Q3; 3rd quarter
   Y       week-based-year             year              1996; 96
   w       week-of-week-based-year     number            27
   W       week-of-month               number            4
   E       day-of-week                 text              Tue; Tuesday; T
   e/c     localized day-of-week       number/text       2; 02; Tue; Tuesday; T
   F       week-of-month               number            3

   a       am-pm-of-day                text              PM
   h       clock-hour-of-am-pm (1-12)  number            12
   K       hour-of-am-pm (0-11)        number            0
   k       clock-hour-of-am-pm (1-24)  number            0

   H       hour-of-day (0-23)          number            0
   m       minute-of-hour              number            30
   s       second-of-minute            number            55
   S       fraction-of-second          fraction          978
   A       milli-of-day                number            1234
   n       nano-of-second              number            987654321
   N       nano-of-day                 number            1234000000

   V       time-zone ID                zone-id           America/Los_Angeles; Z; -08:30
   z       time-zone name              zone-name         Pacific Standard Time; PST
   O       localized zone-offset       offset-O          GMT+8; GMT+08:00; UTC-08:00;
   X       zone-offset 'Z' for zero    offset-X          Z; -08; -0830; -08:30; -083015; -08:30:15;
   x       zone-offset                 offset-x          +0000; -08; -0830; -08:30; -083015; -08:30:15;
   Z       zone-offset                 offset-Z          +0000; -0800; -08:00;

   p       pad next                    pad modifier      1

   '       escape for text             delimiter
   ''      single quote                literal           '
   [       optional section start
   ]       optional section end
   #       reserved for future use
   {       reserved for future use
   }       reserved for future use


回答2:

In DataWeave, you can parse a string to various Java datetime types as well as format them back to strings. Try a parse followed by a format, like so:

payload.date as :localdatetime {format: "M/dd/yyyy  h:mm:ss a"} as :string {format: "MM/dd/yyyy"}

Here's some more detail on date formatting in DataWeave.



回答3:

Hi in dataweave you can write expression like this

formatedDate: |2003-10-01T23:57:59| as :string {format: "MM-dd-YYYY"}


回答4:

You can use this,

var newDate = new Date("8/30/2015  4:00:13 PM");
var dd = newDate.getDate();
var mm = newDate.getMonth()+1; //January is 0!

var yyyy = newDate.getFullYear();
if(dd<10){
    dd='0'+dd
} 
if(mm<10){
    mm='0'+mm
} 
var formattedDate = mm+'/'+dd+'/'+yyyy;
console.log(formattedDate);  //Prints "08/30/2015"

Please refer this