web-dev-qa-db-ja.com

JavaScriptで文字列を日付に変換する

JavaScriptで文字列を日付に変換する方法

var st = "date in some format"
var dt = new date();

var dt_st= //st in date format same as dt
484
jslearner

文字列解析に最適な文字列フォーマットは、JavaScriptのDateオブジェクトコンストラクタと合わせたdate ISOフォーマットです。 

ISOフォーマットの例:YYYY-MM-DDまたはYYYY-MM-DDTHH:MM:SS

しかし待って! 「ISOフォーマット」を使用するだけでは確実に機能しません。文字列は時々UTCとして、そして時々localtime(ブラウザのベンダーとバージョンに基づく)として解析されます。ベストプラクティスは、常に日付をUTCとして格納し、計算をUTCとして行うことです。

日付をUTCとして解析するには、 _ z _ - を追加します(例:new Date('2011-04-11T10:20:30Z'))。

UTCで日付を表示するには、.toUTCString()を使用します。
ユーザーの現地時間で日付を表示するには、.toString()を使用します。

MDN |についてもっと読む日付 そして この答え

古いInternet Explorerとの互換性のため(9より前のIEバージョンはDateコンストラクタでISOフォーマットをサポートしていません)、datetime文字列表現をそれの部分に分割してからdatetime部分を使ってコンストラクタを使うことができます、例えば:new Date('2011', '04' - 1, '11', '11', '51', '00')。月の数は1つ少ない必要があります。


代替方法 - 適切なライブラリを使用します。

指定されたタイムゾーンで日付を解析することができるライブラリ Moment.js を利用することもできます。

636
Pavel Hodek

残念ながら私はそれを見つけました 

var mydate = new Date('2014-04-03');
console.log(mydate.toDateString());

「Wed Apr 02 2014」を返します。私はそれがおかしく聞こえますが、それは何人かのユーザーのために起こります。 

防弾ソリューション は次のとおりです。

var parts ='2014-04-03'.split('-');
// Please pay attention to the month (parts[1]); JavaScript counts months from 0:
// January - 0, February - 1, etc.
var mydate = new Date(parts[0], parts[1] - 1, parts[2]); 
console.log(mydate.toDateString());

200
Roman Podlinov
var st = "26.04.2013";
var pattern = /(\d{2})\.(\d{2})\.(\d{4})/;
var dt = new Date(st.replace(pattern,'$3-$2-$1'));

そして出力は次のようになります。

dt => Date {Fri Apr 26 2013}
103
serega386
function stringToDate(_date,_format,_delimiter)
{
            var formatLowerCase=_format.toLowerCase();
            var formatItems=formatLowerCase.split(_delimiter);
            var dateItems=_date.split(_delimiter);
            var monthIndex=formatItems.indexOf("mm");
            var dayIndex=formatItems.indexOf("dd");
            var yearIndex=formatItems.indexOf("yyyy");
            var month=parseInt(dateItems[monthIndex]);
            month-=1;
            var formatedDate = new Date(dateItems[yearIndex],month,dateItems[dayIndex]);
            return formatedDate;
}

stringToDate("17/9/2014","dd/MM/yyyy","/");
stringToDate("9/17/2014","mm/dd/yyyy","/")
stringToDate("9-17-2014","mm-dd-yyyy","-")
70
Kassem

Date()の引数として渡します。

var st = "date in some format"
var dt = new Date(st);

日付、月、年には、例えばdt.getMonth()を使ってアクセスできます。

28
oblig

moment.js( http://momentjs.com/ )は、使用期限の完全で優れたパッケージで、 ISO 8601文字列をサポートしています

あなたは文字列の日付とフォーマットを追加することができます。

moment("12-25-1995", "MM-DD-YYYY");

日付が有効かどうかを確認できます。

moment("not a real date").isValid(); //Returns false

ドキュメント http://momentjs.com/docs/#/parsing/string-format/ を参照してください。

推奨事項: タイムゾーンとフォーマットの時間管理は本当に大きな問題であるため、jsは多くのフォーマットを解決するので、多くのフォーマットを含む日付にパッケージを使用することをお勧めします。日付を単純な文字列から日付まで簡単に解析できますが、すべての形式と日付のバリエーションをサポートするのは大変な作業です。

18
Juan Caicedo

new Date(2000, 10, 1)はあなたに与えるでしょう "2000年11月1日00:00:00 GMT + 0100(CET)" 

月の0が1月になることを確認してください

17
Torsten Becker

もしあなたが素晴らしい moment ライブラリ(例えばNode.jsプロジェクト)を使うことができれば、あなたは簡単にあなたの日付をパースすることができます。

var momentDate = moment("2014-09-15 09:00:00");

そしてJSの日付オブジェクトにアクセスすることができます

momentDate ().toDate();
17
H6.

タイムスタンプは数値にキャストする必要があります

var ts = '1471793029764';
ts = Number(ts); // cast it to a Number
var date = new Date(ts); // works

var invalidDate = new Date('1471793029764'); // does not work. Invalid Date
11
Lucky Soni

小さくてスマートなソリューションを探している人のために:

String.prototype.toDate = function(format)
{
  var normalized      = this.replace(/[^a-zA-Z0-9]/g, '-');
  var normalizedFormat= format.toLowerCase().replace(/[^a-zA-Z0-9]/g, '-');
  var formatItems     = normalizedFormat.split('-');
  var dateItems       = normalized.split('-');

  var monthIndex  = formatItems.indexOf("mm");
  var dayIndex    = formatItems.indexOf("dd");
  var yearIndex   = formatItems.indexOf("yyyy");
  var hourIndex     = formatItems.indexOf("hh");
  var minutesIndex  = formatItems.indexOf("ii");
  var secondsIndex  = formatItems.indexOf("ss");

  var today = new Date();

  var year  = yearIndex>-1  ? dateItems[yearIndex]    : today.getFullYear();
  var month = monthIndex>-1 ? dateItems[monthIndex]-1 : today.getMonth()-1;
  var day   = dayIndex>-1   ? dateItems[dayIndex]     : today.getDate();

  var hour    = hourIndex>-1      ? dateItems[hourIndex]    : today.getHours();
  var minute  = minutesIndex>-1   ? dateItems[minutesIndex] : today.getMinutes();
  var second  = secondsIndex>-1   ? dateItems[secondsIndex] : today.getSeconds();

  return new Date(year,month,day,hour,minute,second);
};

例:

"22/03/2016 14:03:01".toDate("dd/mm/yyyy hh:ii:ss");
"2016-03-29 18:30:00".toDate("yyyy-mm-dd hh:ii:ss");
11
Arivan Bastos

フォーマット "dd/MM/yyyy"から変換したい場合。これが一例です。

var pattern = /^(\d{1,2})\/(\d{1,2})\/(\d{4})$/;
var arrayDate = stringDate.match(pattern);
var dt = new Date(arrayDate[3], arrayDate[2] - 1, arrayDate[1]);

この解決法は9未満のIEバージョンで動作します。

10
Alex N.

Date.parseはほとんどあなたが望むものを取得します。それはam/pmの部分を絞っていますが、いくらかハッキングすることでそれを動かすことができます:

var str = 'Sun Apr 25, 2010 3:30pm',
    timestamp;

timestamp = Date.parse(str.replace(/[ap]m$/i, ''));

if(str.match(/pm$/i) >= 0) {
    timestamp += 12 * 60 * 60 * 1000;
}
9
niksvp

datejsライブラリをチェックアウトする http://www.datejs.com/ /

6
z33m

new Date(st);だけ

それが正しいフォーマットだと仮定します。

6
Mark Kahn

フォーマットpt-BRに変換:

    var dateString = "13/10/2014";
    var dataSplit = dateString.split('/');
    var dateConverted;

    if (dataSplit[2].split(" ").length > 1) {

        var hora = dataSplit[2].split(" ")[1].split(':');
        dataSplit[2] = dataSplit[2].split(" ")[0];
        dateConverted = new Date(dataSplit[2], dataSplit[1]-1, dataSplit[0], hora[0], hora[1]);

    } else {
        dateConverted = new Date(dataSplit[2], dataSplit[1] - 1, dataSplit[0]);
    }

誰かに手を貸してください!

4

このためのフィドルを作成しました。任意の日付文字列にtoDate()関数を使用して日付形式を指定できます。これはあなたにDateオブジェクトを返します。 https://jsfiddle.net/Sus​​hil231088/q56yd0rp/

"17/9/2014".toDate("dd/MM/yyyy", "/")
4
Sushil Mahajan

JSで文字列を日付に変換するにはhttp://momentjs.com/を使います

moment().format('MMMM Do YYYY, h:mm:ss a'); // August 16th 2015, 4:17:24 pm
moment().format('dddd');                    // Sunday
moment().format("MMM Do YY");               // Aug 16th 15
moment().format('YYYY [escaped] YYYY');     // 2015 escaped 2015
moment("20111031", "YYYYMMDD").fromNow(); // 4 years ago
moment("20120620", "YYYYMMDD").fromNow(); // 3 years ago
moment().startOf('day').fromNow();        // 16 hours ago
moment().endOf('day').fromNow();          // in 8 hours
3
Alexey Popov

DateオブジェクトをUTC Dateオブジェクトに変換するためにこの関数を作りました。

function dateToUTC(date) {
    return new Date(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), date.getUTCHours(), date.getUTCMinutes(), date.getUTCSeconds());
}


dateToUTC(new Date());
2
Andy

もう1つの方法があります:

String.prototype.toDate = function(format) {
    format = format || "dmy";
    var separator = this.match(/[^0-9]/)[0];
    var components = this.split(separator);
    var day, month, year;
    for (var key in format) {
        var fmt_value = format[key];
        var value = components[key];
        switch (fmt_value) {
            case "d":
                day = parseInt(value);
                break;
            case "m":
                month = parseInt(value)-1;
                break;
            case "y":
                year = parseInt(value);
        }
    }
    return new Date(year, month, day);
};
a = "3/2/2017";
console.log(a.toDate("dmy"));
// Date 2017-02-03T00:00:00.000Z
2
Mackraken

日付形式に変換する前に文字列の内容を確認する必要がある場合は、次の手順を実行します。

// Convert 'M/D/YY' to Date()
mdyToDate = function(mdy) {
  var d = mdy.split(/[\/\-\.]/, 3);

  if (d.length != 3) return null;

  // Check if date is valid
  var mon = parseInt(d[0]), 
      day = parseInt(d[1]),
      year= parseInt(d[2]);
  if (d[2].length == 2) year += 2000;
  if (day <= 31 && mon <= 12 && year >= 2015)
    return new Date(year, mon - 1, day);

  return null; 
}
1
Adriano P

var a = "13:15"
var b = toDate(a, "h:m")
alert(b);

function toDate(dStr, format) {
  var now = new Date();
  if (format == "h:m") {
    now.setHours(dStr.substr(0, dStr.indexOf(":")));
    now.setMinutes(dStr.substr(dStr.indexOf(":") + 1));
    now.setSeconds(0);
    return now;
  } else
    return "Invalid Format";
}

1
Kurenai Kunai

あなたはこれを試すことができます:

function formatDate(userDOB) {
  const dob = new Date(userDOB);

  const monthNames = [
    'January', 'February', 'March',
    'April', 'May', 'June', 'July',
    'August', 'September', 'October',
    'November', 'December'
  ];

  const day = dob.getDate();
  const monthIndex = dob.getMonth();
  const year = dob.getFullYear();

  // return day + ' ' + monthNames[monthIndex] + ' ' + year;
  return `${day} ${monthNames[monthIndex]} ${year}`;
}

console.log(formatDate('1982-08-10'));

1
Syed
var date = new Date(year, month, day);

または 

var date = new Date('01/01/1970');

フォーマット '01 -01-1970'の日付文字列はFireFoxでは機能しません。そのため、日付フォーマット文字列には " - "の代わりに "/"を使用してください。

1
Ravi

私はサーバーから日付文字列を取得するときに使用する再利用可能な関数を書きました。
split()メソッドを使用するには、日月と年を区切る区切り文字(/ - etc ..)を渡すことができます。
この 実用例 でそれを見てテストできます。

<!DOCTYPE html>
<html>
  <head>
    <style>
    </style>
  </head>
  <body>
    <div>
      <span>day:
      </span> 
      <span id='day'>
      </span>
    </div>
    <div>
      <span>month:
      </span> 
      <span id='month'>
      </span>
    </div>
    <div>
      <span>year:
      </span> 
      <span id='year'>
      </span>
    </div>
    <br/>
    <input type="button" id="" value="convert" onClick="convert('/','28/10/1980')"/>
    <span>28/10/1980
    </span>
    <script>
      function convert(delimiter,dateString)
      {
        var splitted = dateString.split('/');
        // create a new date from the splitted string 
        var myDate = new Date(splitted[2],splitted[1],splitted[0]);
        // now you can access the Date and use its methods 
        document.getElementById('day').innerHTML = myDate.getDate();
        document.getElementById('month').innerHTML = myDate.getMonth();
        document.getElementById('year').innerHTML = myDate.getFullYear();
      }
    </script>
  </body>
</html>
1
jonathana

Regexを使用して文字列を詳細な時間に解析してから、日付または任意の戻り形式を作成できます。

//example : let dateString = "2018-08-17 01:02:03.4"

function strToDate(dateString){
    let reggie = /(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2}).(\d{1})/
  , [,year, month, day, hours, minutes, seconds, miliseconds] = reggie.exec(dateString)
  , dateObject = new Date(year, month-1, day, hours, minutes, seconds, miliseconds);
  return dateObject;
}
alert(strToDate(dateString));
0
TungHarry

文字列を日付オブジェクトに変換するparseDateTime関数を作成しました。これはすべてのブラウザー(IEブラウザーを含む)で動作し、必要な場合は参照し、参照 https:// github.com/Umesh-Markande/Parse-String-to-Date-in-in-all-browser

    function parseDateTime(datetime) {
            var monthNames = [
                "January", "February", "March",
                "April", "May", "June", "July",
                "August", "September", "October",
                "November", "December"
              ];
            if(datetime.split(' ').length == 3){
                var date = datetime.split(' ')[0];
                var time = datetime.split(' ')[1].replace('.00','');
                var timearray = time.split(':');
                var hours = parseInt(time.split(':')[0]);
                var format = datetime.split(' ')[2];
                var bits = date.split(/\D/);
                date = new Date(bits[0], --bits[1], bits[2]); /* if you change format of datetime which is passed to this function, you need to change bits e.x ( bits[0], bits[1], bits[2 ]) position as per date, months and year it represent bits array.*/
                var day = date.getDate();
                var monthIndex = date.getMonth();
                var year = date.getFullYear();
                if ((format === 'PM' || format === 'pm') && hours !== 12) {
                    hours += 12;
                    try{  time = hours+':'+timearray[1]+':'+timearray[2] }catch(e){ time = hours+':'+timearray[1] }
                } 
                var formateddatetime = new Date(monthNames[monthIndex] + ' ' + day + '  ' + year + ' ' + time);
                return formateddatetime;
            }else if(datetime.split(' ').length == 2){
                var date = datetime.split(' ')[0];
                var time = datetime.split(' ')[1];
                var bits = date.split(/\D/);
                var datetimevalue = new Date(bits[0], --bits[1], bits[2]); /* if you change format of datetime which is passed to this function, you need to change bits e.x ( bits[0], bits[1], bits[2 ]) position as per date, months and year it represent bits array.*/
                var day = datetimevalue.getDate();
                var monthIndex = datetimevalue.getMonth();
                var year = datetimevalue.getFullYear();
                var formateddatetime = new Date(monthNames[monthIndex] + ' ' + day + '  ' + year + ' ' + time);
                return formateddatetime;
            }else if(datetime != ''){
                var bits = datetime.split(/\D/);
                var date = new Date(bits[0], --bits[1], bits[2]); /* if you change format of datetime which is passed to this function, you need to change bits e.x ( bits[0], bits[1], bits[2 ]) position as per date, months and year it represent bits array.*/
                return date;
            }
            return datetime;
        }

    var date1 = '2018-05-14 05:04:22 AM';   // yyyy-mm-dd hh:mm:ss A
    var date2 = '2018/05/14 05:04:22 AM';   // yyyy/mm/dd hh:mm:ss A
    var date3 = '2018/05/04';   // yyyy/mm/dd
    var date4 = '2018-05-04';   // yyyy-mm-dd
    var date5 = '2018-05-14 15:04:22';   // yyyy-mm-dd HH:mm:ss
    var date6 = '2018/05/14 14:04:22';   // yyyy/mm/dd HH:mm:ss

    console.log(parseDateTime(date1))
    console.log(parseDateTime(date2))
    console.log(parseDateTime(date3))
    console.log(parseDateTime(date4))
    console.log(parseDateTime(date5))
    console.log(parseDateTime(date6))

**Output---**
Mon May 14 2018 05:04:22 GMT+0530 (India Standard Time)
Mon May 14 2018 05:04:22 GMT+0530 (India Standard Time)
Fri May 04 2018 00:00:00 GMT+0530 (India Standard Time)
Fri May 04 2018 00:00:00 GMT+0530 (India Standard Time)
Mon May 14 2018 15:04:22 GMT+0530 (India Standard Time)
Mon May 14 2018 14:04:22 GMT+0530 (India Standard Time)
0
Umesh Markande

もう1つの方法は、フォーマット文字列を介して名前付きキャプチャグループを使用して正規表現を作成し、その正規表現を使用して日付文字列から日、月、年を抽出することです。

function parseDate(dateStr, format) {
  const regex = format.toLocaleLowerCase()
    .replace(/\bd+\b/, '(?<day>\\d+)')
    .replace(/\bm+\b/, '(?<month>\\d+)')
    .replace(/\by+\b/, '(?<year>\\d+)')
  
  const parts = new RegExp(regex).exec(dateStr) || {};
  const { year, month, day } = parts.groups || {};
  return parts.length === 4 ? new Date(year, month-1, day) : undefined;
}

const printDate = x => console.log(x ? x.toLocaleDateString() : x);

printDate(parseDate('05/11/1896', 'dd/mm/YYYY'));
printDate(parseDate('07-12-2000', 'dd-mm-yy'));
printDate(parseDate('07:12:2000', 'dd:mm:yy'));
printDate(parseDate('2017/6/3', 'yy/MM/dd'));
printDate(parseDate('2017-6-15', 'y-m-d'));
printDate(parseDate('2015 6 25', 'y m d'));
printDate(parseDate('2015625', 'y m d')); // bad format
0
jo_va

このコードを使用してください:(私の問題はこのコードで解決されました) 

function dateDiff(date1, date2){
var diff = {}                           // Initialisation du retour
var tmp = date2 - date1;

tmp = Math.floor(tmp/1000);             // Nombre de secondes entre les 2 dates
diff.sec = tmp % 60;                    // Extraction du nombre de secondes

tmp = Math.floor((tmp-diff.sec)/60);    // Nombre de minutes (partie entière)
diff.min = tmp % 60;                    // Extraction du nombre de minutes

tmp = Math.floor((tmp-diff.min)/60);    // Nombre d'heures (entières)
diff.hour = tmp % 24;                   // Extraction du nombre d'heures

tmp = Math.floor((tmp-diff.hour)/24);   // Nombre de jours restants
diff.day = tmp;

return diff;

}

0
Fetra
                //little bit of code for Converting dates 

                var dat1 = document.getElementById('inputDate').value;
                var date1 = new Date(dat1)//converts string to date object
                alert(date1);
                var dat2 = document.getElementById('inputFinishDate').value;
                var date2 = new Date(dat2)
                alert(date2);
0
Pec1983

ISO 8601風の日付文字列は、標準と同じくらい優れていますが、まだ広くサポートされていません。 

これはどの日付文字列フォーマットを使うべきかを理解するための素晴らしいリソースです。 

http://dygraphs.com/date-formats.html

はい、それはあなたの日付文字列がではなく同じくらい簡単にできることを意味します 

"2014/10/13 23:57:52"の代わりに"2014-10-13 23:57:52"

0
taveras