वेतन वृद्धि की तिथि एक माह


103

मान लीजिए कि मेरे पास निम्नलिखित प्रारूप में एक तिथि है: 2010-12-11 (वर्ष-सोम-दिन)

PHP के साथ, मैं एक महीने की तारीख बढ़ाना चाहता हूं, और मैं चाहता हूं कि वर्ष अपने आप बढ़े, यदि आवश्यक हो (यानी दिसंबर 2012 से जनवरी 2013 तक वेतन वृद्धि)।

सादर।

जवाबों:


167
$time = strtotime("2010.12.11");
$final = date("Y-m-d", strtotime("+1 month", $time));

// Finally you will have the date you're looking for.

31
यह सभी तिथि के साथ काम नहीं करता है। उदाहरण के लिए 2013-05-31 अगले महीने के बजाय जुलाई को प्रदर्शित करेगा जो जून है।
पैट्रिक डेसजार्डिन्स

1
मैं 2014-01-31 के लिए 2014-03-03 का अनुसरण कर रहा हूं?
मनीष गोयल

इस स्ट्रिंग के साथ काम नहीं किया: "2014-06-19 15:00:19"
मीटाई.कॉम

1
यह कभी-कभी टूटता है। @Ajon द्वारा उत्तर तकनीकी रूप से अधिक सही है क्योंकि यह लीप वर्ष, महीने की लंबाई, और इसी तरह की चीजों के लिए जिम्मेदार है। इसे सही उत्तर के रूप में चिह्नित किया जाना चाहिए।
भाषा

4
यह उत्तर खतरनाक है क्योंकि यह "महीने के अंतिम दिन" के परिदृश्यों में विफल रहता है जिसका पता लगाना कठिन है।
ckonig

43

मुझे मासिक चक्र (प्लस महीने, शून्य से 1 दिन) को छोड़कर समान कार्यक्षमता की आवश्यकता थी। थोड़ी देर के लिए एसओ की खोज करने के बाद, मैं इस प्लग-एन-प्ले समाधान को तैयार करने में सक्षम था:

function add_months($months, DateTime $dateObject) 
    {
        $next = new DateTime($dateObject->format('Y-m-d'));
        $next->modify('last day of +'.$months.' month');

        if($dateObject->format('d') > $next->format('d')) {
            return $dateObject->diff($next);
        } else {
            return new DateInterval('P'.$months.'M');
        }
    }

function endCycle($d1, $months)
    {
        $date = new DateTime($d1);

        // call second function to add the months
        $newDate = $date->add(add_months($months, $date));

        // goes back 1 day from date, remove if you want same day of month
        $newDate->sub(new DateInterval('P1D')); 

        //formats final date to Y-m-d form
        $dateReturned = $newDate->format('Y-m-d'); 

        return $dateReturned;
    }

उदाहरण:

$startDate = '2014-06-03'; // select date in Y-m-d format
$nMonths = 1; // choose how many months you want to move ahead
$final = endCycle($startDate, $nMonths); // output: 2014-07-02

3
बहुत बढ़िया, बस मुझे जो चाहिए था। मुझे बहुत समय बचाने के लिए धन्यवाद!
तुम

कोई बात नहीं, खुशी है कि आप इसे उपयोगी पाया
जेसन

धन्यवाद जेसन, यह बहुत मददगार था। मैंने इसे सुधार लिया और अधिक टिप्पणियाँ जोड़कर मुझे यह सब समझने में मदद की। ऐसे मामले में जो किसी की मदद करता है, मैंने इसे और नीचे पोस्ट किया है (इसे यहां जोड़ने की कोशिश की लेकिन यह बहुत लंबा था)।
ग्रेग

1
हालांकि यह 30 जनवरी और 31 जनवरी के लिए समान मूल्य देता है!
सिटिज

एक आकर्षण की तरह काम करता है, बस इसे 31 जनवरी, धन्यवाद के माध्यम से 2020 जनवरी 1 के लिए परीक्षण किया!
पॉल नोवाक

34

का उपयोग करें DateTime::add

$start = new DateTime("2010-12-11", new DateTimeZone("UTC"));
$month_later = clone $start;
$month_later->add(new DateInterval("P1M"));

मैंने क्लोन का उपयोग किया क्योंकि मूल वस्तु को संशोधित करता है, जो वांछित नहीं हो सकता है।


1
काम नहीं करता है .. (नया DateTime ("2010-01-31", नया DateTimeZone ("UTC"))) -> जोड़ें (नया DateInterval ("P1M")) -> प्रारूप ('Ym-d') परिणाम 2010-03-03
Scholtz

13
strtotime( "+1 month", strtotime( $time ) );

यह एक टाइमस्टैम्प लौटाता है जिसे दिनांक फ़ंक्शन के साथ उपयोग किया जा सकता है


@ गैलन: यह काम नहीं करता है, गलत तारीख देता है .... कृपया बताएं कि अपनी पद्धति का उपयोग कैसे करें, यहां $ समय का मूल्य क्या है?
sqlchild

यह काम नहीं करता है, गलत तारीख देता है .... कृपया बताएं कि अपनी पद्धति का उपयोग कैसे करें, यहां $ समय का मूल्य क्या है?
sqlchild

स्वीकृत उत्तर के रूप में भी यही समस्या है। सभी तारों पर काम नहीं करता है।
मीटाइ.कॉम

यह मेरे लिए काम करता है (बेशक $timeएक प्रारंभिक मूल्य है)।
tatskie

6
(date('d') > 28) ? date("mdY", strtotime("last day of next month")) : date("mdY", strtotime("+1 month"));

यह फरवरी और अन्य 31 दिन के महीनों के लिए क्षतिपूर्ति करेगा। आप निश्चित रूप से 'इस महीने के अगले महीने' के सापेक्ष तारीख प्रारूपों (जो दुख की बात नहीं है, नीचे देखें) के लिए और अधिक सटीक प्राप्त करने के लिए बहुत अधिक जाँच कर सकते हैं, और आप बस डेटाइम का उपयोग कर सकते हैं।

दोनों DateInterval('P1M')और strtotime("+1 month")अनिवार्य रूप से आँख बंद करके अगले महीने में दिनों की संख्या की परवाह किए बिना 31 दिन जोड़ रहे हैं।

  • 2010-01-31 => 3 मार्च
  • 2012-01-31 => 2 मार्च (लीप वर्ष)

3
"अगले महीने में दिनों की संख्या की परवाह किए बिना 31 दिन जोड़ना", बिल्कुल सही! (+1)।
जोस मैनुअल अबरका रोड्रिगेज

6

आप DateTime::modifyइस तरह का उपयोग कर सकते हैं :

$date = new DateTime('2010-12-11');
$date->modify('+1 month');

दस्तावेज देखें:

http://php.net/manual/fr/datetime.modify.php

http://php.net/manual/fr/class.datetime.php


1
यह 31 मई से 1 जुलाई तक कूदता है जो गलत है
ckonig

हां वास्तव में ... मैं इस समस्या को हल करने के लिए अपने पोस्ट को संपादित करूंगा
HRoux

5

मैं इस तरह से उपयोग करता हूं: -

 $occDate='2014-01-28';
 $forOdNextMonth= date('m', strtotime("+1 month", strtotime($occDate)));
//Output:- $forOdNextMonth=02


/*****************more example****************/
$occDate='2014-12-28';

$forOdNextMonth= date('m', strtotime("+1 month", strtotime($occDate)));
//Output:- $forOdNextMonth=01

//***********************wrong way**********************************//
$forOdNextMonth= date('m', strtotime("+1 month", $occDate));
  //Output:- $forOdNextMonth=02; //instead of $forOdNextMonth=01;
//******************************************************************//

1
यह मेरे लिए काम करता है धन्यवाद। लेकिन, तारीख ('एम', स्ट्रैटिओम ("+ 1 महीना", स्ट्रटोटाइम ($ occDate)) और तारीख ('एम'), स्ट्रॉटटाइम ("+ 1 महीना", $ ऑकडेट)) एक ही काम करते हैं।

1
नहीं, दोनों में अंतर @ sah.cyBuzzSc है। उदाहरण पर विचार करें: - $ occDate = '2014-12-28'; $ forOdNextMonth = दिनांक ('m', strtotime ("+ 1 महीना", $ occDate)); मूल्य $ forOdNextMonth 02 है
विनीत

@chotesah समझाने के लिए धन्यवाद। आपका दूसरा उदाहरण काफी अच्छा है।

3

कृपया पहले अपना दिनांक प्रारूप 12-12-2012 की तरह सेट करें

इस फ़ंक्शन का उपयोग करने के बाद यह ठीक से काम करता है;

$date =  date('d-m-Y',strtotime("12-12-2012 +2 Months");

यहाँ १२-१२-२०१२ आपकी तिथि है और +२ महीने का वेतन वृद्धि है;

आप वर्ष, दिनांक की वृद्धि भी करते हैं

strtotime("12-12-2012 +1 Year");

Ans 12-12-2013 है


1

धन्यवाद जेसन, आपकी पोस्ट बहुत मददगार थी। मैंने इसे सुधार लिया और अधिक टिप्पणियाँ जोड़कर मुझे यह सब समझने में मदद की। किसी की मदद करने के मामले में, मैंने इसे यहाँ पोस्ट किया है:

function cycle_end_date($cycle_start_date, $months) {
    $cycle_start_date_object = new DateTime($cycle_start_date);

    //Find the date interval that we will need to add to the start date
    $date_interval = find_date_interval($months, $cycle_start_date_object);

    //Add this date interval to the current date (the DateTime class handles remaining complexity like year-ends)
    $cycle_end_date_object = $cycle_start_date_object->add($date_interval);

    //Subtract (sub) 1 day from date
    $cycle_end_date_object->sub(new DateInterval('P1D')); 

    //Format final date to Y-m-d
    $cycle_end_date = $cycle_end_date_object->format('Y-m-d'); 

    return $cycle_end_date;
}

//Find the date interval we need to add to start date to get end date
function find_date_interval($n_months, DateTime $cycle_start_date_object) {
    //Create new datetime object identical to inputted one
    $date_of_last_day_next_month = new DateTime($cycle_start_date_object->format('Y-m-d'));

    //And modify it so it is the date of the last day of the next month
    $date_of_last_day_next_month->modify('last day of +'.$n_months.' month');

    //If the day of inputted date (e.g. 31) is greater than last day of next month (e.g. 28)
    if($cycle_start_date_object->format('d') > $date_of_last_day_next_month->format('d')) {
        //Return a DateInterval object equal to the number of days difference
        return $cycle_start_date_object->diff($date_of_last_day_next_month);
    //Otherwise the date is easy and we can just add a month to it
    } else {
        //Return a DateInterval object equal to a period (P) of 1 month (M)
        return new DateInterval('P'.$n_months.'M');
    }
}

$cycle_start_date = '2014-01-31'; // select date in Y-m-d format
$n_months = 1; // choose how many months you want to move ahead
$cycle_end_date = cycle_end_date($cycle_start_date, $n_months); // output: 2014-07-02

1
$date = strtotime("2017-12-11");
$newDate = date("Y-m-d", strtotime("+1 month", $date));

यदि आप दिनों के हिसाब से बढ़ाना चाहते हैं तो आप भी कर सकते हैं

$date = strtotime("2017-12-11");
$newDate = date("Y-m-d", strtotime("+5 day", $date));

1

केवल महीनों के बाद तारीख खोजने के लिए सरल विधि के साथ उत्तर को अपडेट करना। सबसे अच्छा जवाब के रूप में चिह्नित सही समाधान नहीं देता है।

<?php

    $date = date('2020-05-31');
    $current = date("m",strtotime($date));
    $next = date("m",strtotime($date."+1 month"));
    if($current==$next-1){
        $needed = date('Y-m-d',strtotime($date." +1 month"));
    }else{
        $needed = date('Y-m-d', strtotime("last day of next month",strtotime($date)));
    }
    echo "Date after 1 month from 2020-05-31 would be : $needed";

?>

केवल यह +1 महीने की तारीख के लिए सही समाधान है।
असद ऐप

0
function dayOfWeek($date){
    return DateTime::createFromFormat('Y-m-d', $date)->format('N');
}

उपयोग के उदाहरण:

echo dayOfWeek(2016-12-22);
// "4"
echo dayOfWeek(date('Y-m-d'));
// "4"

0

किसी भी तिथि प्रारूप के उत्तर की तलाश में किसी के लिए।

echo date_create_from_format('d/m/Y', '15/04/2017')->add(new DateInterval('P1M'))->format('d/m/Y');

बस दिनांक प्रारूप बदलें।


-2

इनपुट बॉक्स में एक तारीख डालें और फिर बटन को क्लिक करें, जिस दिन से jquery में तारीख मिलती है

$(document).ready( function() {
    $("button").click(function(){   
    var day = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"];
    var a = new Date();
    $(".result").text(day[a.getDay()]);

    });  
             });

-2
 <?php
              $selectdata ="select fromd,tod  from register where username='$username'";
            $q=mysqli_query($conm,$selectdata);
            $row=mysqli_fetch_array($q);

            $startdate=$row['fromd']; 
            $stdate=date('Y', strtotime($startdate));  

            $endate=$row['tod']; 
            $enddate=date('Y', strtotime($endate));  

            $years = range ($stdate,$enddate);
            echo '<select name="years" class="form-control">';
            echo '<option>SELECT</option>';
            foreach($years as $year)
              {   echo '<option value="'.$year.'"> '.$year.' </option>';  }
                echo '</select>'; ?>

2
कॉपी पेस्ट कोड हमेशा मदद नहीं करता है। आपको कोड को भी थोड़ा समझाना चाहिए।
mrkernelpanic

-2

सभी प्रस्तुत समाधान ठीक से काम नहीं कर रहे हैं।
strtotime () और DateTime :: जोड़ें या DateTime :: संशोधित करें कुछ समय के लिए अमान्य परिणाम।
उदाहरण:
- 31.08.2019 + 1 महीना 30.09.2019 के बजाय 01.10.2019
- 29.02.2020 + 1 वर्ष 28.03.2021 के बजाय 01.03.2021 देता है
(PHP 5.5, PHP 7.3 पर परीक्षण किया गया)

नीचे मेरा कार्य एंजेलो द्वारा पोस्ट किए गए विचार पर आधारित है जो समस्या को हल करता है:

// $time - unix time or date in any format accepted by strtotime() e.g. 2020-02-29  
// $days, $months, $years - values to add
// returns new date in format 2021-02-28
function addTime($time, $days, $months, $years)
{
    // Convert unix time to date format
    if (is_numeric($time))
    $time = date('Y-m-d', $time);

    try
    {
        $date_time = new DateTime($time);
    }
    catch (Exception $e)
    {
        echo $e->getMessage();
        exit;
    }

    if ($days)
    $date_time->add(new DateInterval('P'.$days.'D'));

    // Preserve day number
    if ($months or $years)
    $old_day = $date_time->format('d');

    if ($months)
    $date_time->add(new DateInterval('P'.$months.'M'));

    if ($years)
    $date_time->add(new DateInterval('P'.$years.'Y'));

    // Patch for adding months or years    
    if ($months or $years)
    {
        $new_day = $date_time->format("d");

        // The day is changed - set the last day of the previous month
        if ($old_day != $new_day)
        $date_time->sub(new DateInterval('P'.$new_day.'D'));
    }
    // You can chage returned format here
    return $date_time->format('Y-m-d');
}

उपयोग के उदाहरण:

echo addTime('2020-02-29', 0, 0, 1); // add 1 year (result: 2021-02-28)
echo addTime('2019-08-31', 0, 1, 0); // add 1 month (result: 2019-09-30)
echo addTime('2019-03-15', 12, 2, 1); // add 12 days, 2 months, 1 year (result: 2019-09-30)
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.