Ma date de chaîne d’entrée est la suivante:
Ssortingng date = "1/13/2012";
Je reçois le mois comme ci-dessous:
SimpleDateFormat dateFormat = new SimpleDateFormat("MM/dd/yyyy"); Date convertedDate = dateFormat.parse(date); Ssortingng month = new SimpleDateFormat("MM").format(convertedDate);
Mais comment puis-je obtenir le dernier jour civil du mois dans une date de chaîne donnée?
Par exemple: pour une chaîne "1/13/2012"
la sortie doit être "1/31/2012"
.
En utilisant convertedDate.getMonth().length(convertedDate.isLeapYear())
LocalDate
convertedDate.getMonth().length(convertedDate.isLeapYear())
où LocalDate
est une instance de LocalDate
.
Ssortingng date = "1/13/2012"; LocalDate convertedDate = LocalDate.parse(date, DateTimeFormatter.ofPattern("M/d/yyyy")); convertedDate = convertedDate.withDayOfMonth( convertedDate.getMonth().length(convertedDate.isLeapYear()));
En utilisant la méthode getActualMaximum
de java.util.Calendar
:
Ssortingng date = "1/13/2012"; SimpleDateFormat dateFormat = new SimpleDateFormat("MM/dd/yyyy"); Date convertedDate = dateFormat.parse(date); Calendar c = Calendar.getInstance(); c.setTime(convertedDate); c.set(Calendar.DAY_OF_MONTH, c.getActualMaximum(Calendar.DAY_OF_MONTH));
Cela ressemble à vos besoins:
http://obscuredclarity.blogspot.de/2010/08/get-last-day-of-month-date-object-in.html
code:
import java.text.DateFormat; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; //Java 1.4+ Compatible // // The following example code demonstrates how to get // a Date object representing the last day of the month // relative to a given Date object. public class GetLastDayOfMonth { public static void main(Ssortingng[] args) { Date today = new Date(); Calendar calendar = Calendar.getInstance(); calendar.setTime(today); calendar.add(Calendar.MONTH, 1); calendar.set(Calendar.DAY_OF_MONTH, 1); calendar.add(Calendar.DATE, -1); Date lastDayOfMonth = calendar.getTime(); DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); System.out.println("Today : " + sdf.format(today)); System.out.println("Last Day of Month: " + sdf.format(lastDayOfMonth)); } }
Sortie:
Today : 2010-08-03 Last Day of Month: 2010-08-31
Avec Java 8
DateTime
/LocalDateTime
:
Ssortingng dateSsortingng = "01/13/2012"; DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("MM/dd/yyyy", Locale.US); LocalDate date = LocalDate.parse(dateSsortingng, dateFormat); ValueRange range = date.range(ChronoField.DAY_OF_MONTH); Long max = range.getMaximum(); LocalDate newDate = date.withDayOfMonth(max.intValue()); System.out.println(newDate);
OU
Ssortingng dateSsortingng = "01/13/2012"; DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("MM/dd/yyyy", Locale.US); LocalDate date = LocalDate.parse(dateSsortingng, dateFormat); LocalDate newDate = date.withDayOfMonth(date.getMonth().maxLength()); System.out.println(newDate);
Sortie:
2012-01-31
LocalDateTime
devrait être utilisé à la place deLocalDate
si vous avez des informations de temps dans votre chaîne de date. IE2015/07/22 16:49
En utilisant java 8 java.time.LocalDate
Ssortingng date = "1/13/2012"; LocalDate localDate = LocalDate.parse(date,DateTimeFormatter.ofPattern("MM/dd/yyyy")); lastDayOfMonth = localDate.with(TemporalAdjusters.lastDayOfMonth());
La manière la plus simple est de construire une nouvelle instance de GregorianCalendar
, voir ci-dessous:
Calendar cal = new GregorianCalendar(2013, 5, 0); Date date = cal.getTime(); DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); System.out.println("Date : " + sdf.format(date));
Sortie:
Date : 2013-05-31
Attention:
month la valeur utilisée pour définir le champ MONTH calendar dans le calendrier. La valeur du mois est basée sur 0, par exemple 0 pour janvier.
Utilisez GregorianCalendar
. Définissez la date de l’object, puis utilisez getActualMaximum(Calendar.DAY_IN_MONTH)
.
http://docs.oracle.com/javase/7/docs/api/java/util/GregorianCalendar.html#getActualMaximum%28int%29 (mais c’était la même chose avec Java 1.4)
Vous pouvez utiliser le code suivant pour obtenir le dernier jour du mois
public static Ssortingng getLastDayOfTheMonth(Ssortingng date) { Ssortingng lastDayOfTheMonth = ""; SimpleDateFormat formatter = new SimpleDateFormat("dd-MM-yyyy"); try{ java.util.Date dt= formatter.parse(date); Calendar calendar = Calendar.getInstance(); calendar.setTime(dt); calendar.add(Calendar.MONTH, 1); calendar.set(Calendar.DAY_OF_MONTH, 1); calendar.add(Calendar.DATE, -1); java.util.Date lastDay = calendar.getTime(); lastDayOfTheMonth = formatter.format(lastDay); } catch (ParseException e) { e.printStackTrace(); } return lastDayOfTheMonth; }
Fonctionne bien pour moi avec cela
Calendar cal = Calendar.getInstance(TimeZone.getTimeZone()); cal.set(Calendar.MONTH, month-1); cal.set(Calendar.YEAR, year); cal.add(Calendar.DATE, -1); cal.set(Calendar.DAY_OF_MONTH, cal.getActualMaximum(Calendar.DAY_OF_MONTH)); cal.set(Calendar.HOUR_OF_DAY, 0); cal.set(Calendar.MINUTE, 0); cal.set(Calendar.SECOND, 0); cal.set(Calendar.MILLISECOND, 0); return cal.getTimeInMillis();
public static Ssortingng getLastDayOfMonth(int year, int month) throws Exception{ DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date date = sdf.parse(year+"-"+(month<10?("0"+month):month)+"-01"); Calendar calendar = Calendar.getInstance(); calendar.setTime(date); calendar.add(Calendar.MONTH, 1); calendar.set(Calendar.DAY_OF_MONTH, 1); calendar.add(Calendar.DATE, -1); Date lastDayOfMonth = calendar.getTime(); return sdf.format(lastDayOfMonth); } public static void main(String[] args) throws Exception{ System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 1)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 3)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 4)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 5)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 6)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 7)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 8)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 9)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 10)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 11)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 12)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2018, 1)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2018, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2018, 3)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2010, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2011, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2012, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2013, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2014, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2015, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2016, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2017, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2018, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2019, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2020, 2)); System.out.println("Last Day of Month: " + getLastDayOfMonth(2021, 2)); }
sortie:
Dernier jour du mois: 2017-01-31
Dernier jour du mois: 2017-02-28
Dernier jour du mois: 2017-03-31
Dernier jour du mois: 2017-04-30
Dernier jour du mois: 2017-05-31
Dernier jour du mois: 2017-06-30
Dernier jour du mois: 2017-07-31
Dernier jour du mois: 2017-08-31
Dernier jour du mois: 2017-09-30
Dernier jour du mois: 2017-10-31
Dernier jour du mois: 2017-11-30
Dernier jour du mois: 2017-12-31
Dernier jour du mois: 2018-01-31
Dernier jour du mois: 2018-02-28
Dernier jour du mois: 2018-03-31
Dernier jour du mois: 2010-02-28
Dernier jour du mois: 2011-02-28
Dernier jour du mois: 2012-02-29
Dernier jour du mois: 2013-02-28
Dernier jour du mois: 2014-02-28
Dernier jour du mois: 2015-02-28
Dernier jour du mois: 2016-02-29
Dernier jour du mois: 2017-02-28
Dernier jour du mois: 2018-02-28
Dernier jour du mois: 2019-02-28
Dernier jour du mois: 2020-02-29
Dernier jour du mois: 2021-02-28
J’utilise ce one-liner sur mes rapports JasperServer:
new SimpleDateFormat("yyyy-MM-dd").format(new SimpleDateFormat("yyyy-MM-dd").parse(new java.util.Date().format('yyyy') + "-" + (new Integer (new SimpleDateFormat("MM").format(new Date()))+1) + "-01")-1)
Ça n’a pas l’air sympa mais ça marche pour moi. Fondamentalement, il ajoute 1 au mois en cours, obtient le premier jour de ce mois et soustrait un jour.