দুই তারিখের মধ্যে দিনের সংখ্যা গণনা করুন অথবা একটি নির্দিষ্ট সময়ের পরে একটি তারিখ খুঁজুন। প্রকল্প পরিকল্পনা, ইভেন্ট সময়সূচী, এবং আর্থিক গণনার জন্য উপকারী।
দিন সংখ্যা গণক একটি বহুমুখী সরঞ্জাম যা ব্যবহারকারীদের দুটি তারিখের মধ্যে দিন সংখ্যা গণনা করতে এবং একটি নির্দিষ্ট শুরু তারিখের আগে বা পরে নির্দিষ্ট সংখ্যক দিন দ্বারা তারিখ নির্ধারণ করতে সক্ষম করে। এই গণক প্রকল্প ব্যবস্থাপনা, আর্থিক পরিকল্পনা এবং ইভেন্ট সময়সূচী তৈরির জন্য অপরিহার্য।
দুটি তারিখের মধ্যে দিন সংখ্যা গণনা করা হয় উভয় তারিখকে একটি সাধারণ সময় উপস্থাপনায় (সাধারণত ইউনিক্স টাইমস্ট্যাম্প বা জুলিয়ান তারিখ) রূপান্তর করে এবং তারপরে এই উপস্থাপনাগুলির মধ্যে পার্থক্য খুঁজে বের করে। এই পদ্ধতি নিম্নলিখিত বিষয়গুলি বিবেচনায় নেয়:
দুটি তারিখের (date1 এবং date2) মধ্যে দিন সংখ্যা গণনা করার জন্য মৌলিক সূত্র হল:
1days_between = |date2_timestamp - date1_timestamp| / (86400)
2
যেখানে টাইমস্ট্যাম্পগুলি সেকেন্ডে রয়েছে, এবং ৮৬৪০০ (২৪ * ৬০ * ৬০) দ্বারা ভাগ করা সেকেন্ডকে দিনে রূপান্তর করে।
আরও সঠিক গণনার জন্য, বিশেষ করে যখন ঐতিহাসিক তারিখ বা বিভিন্ন ক্যালেন্ডার সিস্টেমের সাথে কাজ করা হয়, আরও জটিল অ্যালগরিদম যেমন জুলিয়ান ডে নাম্বার (JDN) রূপান্তর ব্যবহার করা হয়।
জুলিয়ান তারিখ (JD) হল জুলিয়ান পিরিয়ডের শুরু থেকে দিনগুলির একটি অবিচ্ছিন্ন গণনা। এটি জ্যোতির্বিজ্ঞানী গণনায় ব্যবহৃত হয় এবং বিভিন্ন ক্যালেন্ডার সিস্টেমের মধ্যে তারিখগুলি উপস্থাপন করার একটি মানক উপায় প্রদান করে। একটি গ্রেগরিয়ান তারিখকে জুলিয়ান তারিখে রূপান্তর করার সূত্র হল:
JD = (1461 * (Y + 4800 + (M - 14)/12))/4 + (367 * (M - 2 - 12 * ((M - 14)/12)))/12 - (3 * ((Y + 4900 + (M - 14)/12)/100))/4 + D - 32075
যেখানে:
এই গণনা লিপ বছর এবং জুলিয়ান ও গ্রেগরিয়ান ক্যালেন্ডারের মধ্যে পরিবর্তন বিবেচনায় নেয়।
দিন সংখ্যা গণকটির বিভিন্ন ব্যবহারিক আবেদন রয়েছে:
যদিও দিন সংখ্যা গণকটি বহুমুখী, নির্দিষ্ট সময় সম্পর্কিত গণনার জন্য বিকল্প পদ্ধতিও রয়েছে:
এখানে বিভিন্ন প্রোগ্রামিং ভাষায় দুটি তারিখের মধ্যে দিন সংখ্যা গণনা এবং একটি নির্দিষ্ট সংখ্যক দিন পরে একটি তারিখ নির্ধারণ করার উদাহরণ রয়েছে:
1' Excel সূত্র দুটি তারিখের মধ্যে দিন গণনা করতে
2=DATEDIF(A1, B1, "D")
3
4' Excel সূত্র নির্দিষ্ট সংখ্যক দিন পরে তারিখ গণনা করতে
5=A1 + C1
6
1from datetime import datetime, timedelta
2
3def days_between_dates(start_date, end_date):
4 return (end_date - start_date).days
5
6def date_after_period(start_date, days):
7 return start_date + timedelta(days=days)
8
9## উদাহরণ ব্যবহার
10start = datetime(2023, 1, 1)
11end = datetime(2023, 12, 31)
12print(f"দিন সংখ্যা: {days_between_dates(start, end)}")
13print(f"১০০ দিনের পরে তারিখ: {date_after_period(start, 100)}")
14
1function daysBetweenDates(startDate, endDate) {
2 const oneDay = 24 * 60 * 60 * 1000; // ঘণ্টা*মিনিট*সেকেন্ড*মিলিসেকেন্ড
3 const diffDays = Math.round(Math.abs((startDate - endDate) / oneDay));
4 return diffDays;
5}
6
7function dateAfterPeriod(startDate, days) {
8 const result = new Date(startDate);
9 result.setDate(result.getDate() + days);
10 return result;
11}
12
13// উদাহরণ ব্যবহার
14const start = new Date(2023, 0, 1); // ১ জানুয়ারী, ২০২৩
15const end = new Date(2023, 11, 31); // ৩১ ডিসেম্বর, ২০২৩
16console.log(`দিন সংখ্যা: ${daysBetweenDates(start, end)}`);
17console.log(`১০০ দিনের পরে তারিখ: ${dateAfterPeriod(start, 100)}`);
18
1import java.time.LocalDate;
2import java.time.temporal.ChronoUnit;
3
4public class DateCalculator {
5 public static long daysBetweenDates(LocalDate startDate, LocalDate endDate) {
6 return ChronoUnit.DAYS.between(startDate, endDate);
7 }
8
9 public static LocalDate dateAfterPeriod(LocalDate startDate, long days) {
10 return startDate.plusDays(days);
11 }
12
13 public static void main(String[] args) {
14 LocalDate start = LocalDate.of(2023, 1, 1);
15 LocalDate end = LocalDate.of(2023, 12, 31);
16 System.out.println("দিন সংখ্যা: " + daysBetweenDates(start, end));
17 System.out.println("১০০ দিনের পরে তারিখ: " + dateAfterPeriod(start, 100));
18 }
19}
20
এখানে একটি SVG ডায়াগ্রাম রয়েছে যা তারিখের মধ্যে দিন সংখ্যা গণনার ধারণাটি চিত্রিত করে:
এই ডায়াগ্রামটি দুটি তারিখের মধ্যে দিন সংখ্যা গণনার ধারণাটি দৃশ্যমানভাবে উপস্থাপন করে, বাম দিকে শুরু তারিখ, ডান দিকে শেষ তারিখ এবং তাদের মধ্যে সংযোগকারী তীর দ্বারা দিন সংখ্যা উপস্থাপন করা হয়েছে।
দিন সংখ্যা গণক বিভিন্ন সময় সম্পর্কিত গণনার জন্য একটি শক্তিশালী সরঞ্জাম। গণনার মৌলিক পদ্ধতিগুলি, জুলিয়ান তারিখ সিস্টেম সহ, বোঝার মাধ্যমে ব্যবহারকারীরা প্রকল্প পরিকল্পনা, আর্থিক গণনা এবং ইভেন্ট সময়সূচী তৈরিতে তথ্যভিত্তিক সিদ্ধান্ত নিতে পারেন। প্রদত্ত কোড উদাহরণ এবং ভিজ্যুয়ালাইজেশন ধারণাটি এবং বিভিন্ন প্রোগ্রামিং ভাষায় বাস্তবায়নটি বোঝাতে সহায়তা করে।
আপনার কাজে দরকারী হতে পারে আরো টুল খুঁজে বের করুন