آموزش های این وب سایت به صورت رایگان در دسترس است. اطلاعات بیشتر
مشکل عدم دسترسی خریداران پیشین به برخی آموزش ها برطرف شد
بروز خطا
   [message]
اشتراک در سوال
رای ها
[dataList]

محاصبه اختلاف دو تاریخ دوستان راهنمایی کنید فوری ...

mrz  7 سال پیش  5 سال پیش
0 0

وقتی میخوام دو تا رشته تاریخ از ورودی بگیره واختلاف دو تاریخ و حساب کنه  وقتی داخل " " تاریخ و قرار میدم محاصبه صحیح انجام میده چون عبارت بین " " مقایسه میشه
String s = db.query("SELECT * FROM earnings Where Id=" + i + " AND (Date BETWEEN '"+"1395/1/10"+"' AND '"+"1395/12/1"+"' )", 3);
اما وقتی همین عبارت و از ورودی بگیرم حاصل تقسیم شده شو حساب میکنه و جواب نمیده
String s = db.query("SELECT * FROM earnings Where Id=" + i + " AND (Date BETWEEN '"+start_Date+"' AND '"+end_Date+"' )", 3);اگه تاریخ شروع و 1395/12/1 بدم حاصل 116 و مقایسه میکنه چکار کنم ؟

0 0
کد رو کاملتر و داخل تگ کد بزارین تا بشه بهتر راهنمایی کرد (7 سال پیش)
 برای این سوال 1 پاسخ وجود دارد.
پاسخ به سوال 
116236  5 سال پیش
0 0

این کد تست شده و جواب داده:

 

من این کد رو استفاده کردم، جواب داد:

    /**
     * return format: yyyy/MM/dd hh:mm
     *
     */
    public static String getCurrentDate_MiladiWithTime() {

        Calendar cal = Calendar.getInstance();
        int Day = cal.get(Calendar.DAY_OF_MONTH);
        int Month = cal.get(Calendar.MONTH) + 1;
        int Year = cal.get(Calendar.YEAR);

        Time now = new Time(Time.getCurrentTimezone());
        now.setToNow();

        String today = Year + "/" + Month + "/" + Day + " " + now.format("%k:%M");
        return today;

    }


    /**
     * form of input data:yyyy/MM/dd HH:mm;
     *
     */

     public static String calculate_new(String targetDate) {
        Log.i("LOG", targetDate);

        String nowDate = getCurrentDate_MiladiWithTime();

        //HH converts hour in 24 hours format (0-23), day calculation
        SimpleDateFormat format = new SimpleDateFormat("yyyy/MM/dd HH:mm");

        Date d1 = null;
        Date d2 = null;

        String returnValue = "";

        try {
            d1 = format.parse(targetDate);
            d2 = format.parse(nowDate);

            //in milliseconds
            long diff = (d2.getTime() - d1.getTime()) / 1000;

            int minute = 60;
            int hour = minute * 60;
            int day = hour * 24;
            int month = day * 30;
            int year = day * 365;

            
            int diffYears = (int) Math.floor(diff / year);
            diff -= diffYears * year;
            int diffMonthes = (int) Math.floor(diff / month);
            diff -= diffMonthes * month;
            int diffDays = (int) Math.floor(diff / day);
            diff -= diffDays * day;
            int diffHours = (int) Math.floor(diff / hour);
            diff -= diffHours * hour;
            int diffMinutes = (int) Math.floor(diff / minute);
             

            /*
             //if you don't need all item simultaneously and want all values complete:
            
            int diffYears = (int) Math.floor(diff / year);
            int diffMonthes = (int) Math.floor(diff / month);
            int diffDays = (int) Math.floor(diff / day);
            int diffHours = (int) Math.floor(diff / hour);
            int diffMinutes = (int) Math.floor(diff / minute);
             */

            Log.i("LOG", diffYears + " years, ");
            Log.i("LOG", diffMonthes + " monthes, ");
            Log.i("LOG", diffDays + " days, ");
            Log.i("LOG", diffHours + " hours, ");
            Log.i("LOG", diffMinutes + " minutes, ");
            Log.i("LOG", diff + " diff, ");

            if (diffYears != 0) {
                returnValue = diffYears + " " + "سال";

            } else if (diffMonthes != 0) {
                returnValue = diffMonthes + " " + "ماه";

            } else if (diffDays != 0) {
                returnValue = diffDays + " " + "روز";

            } else if (diffHours != 0) {
                returnValue = diffHours + " " + "ساعت";

            } else if (diffMinutes != 0) {
                returnValue = diffMinutes + " " + "دقیقه";

            } else {
                returnValue = "لحظه ای";

            }

        }
        catch (Exception e) {
            e.printStackTrace();
        }

        return returnValue + " قبل";

    }

پاسخگویی و مشاهده پاسخ های این سوال تنها برای اعضای ویژه سایت امکان پذیر است .
چنانچه تمایل دارید به همه بخش ها دسترسی داشته باشید میتوانید از این بخش لایسنس این آموزش را خریداری نمایید .