Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,027

HOME > PHP > PHP Forum > อยากทราบวิธีหาว่าอยู่สัปดาห์ที่เท่าไหร่ โดยกำหนดวันเริ่มต้นและวันที่ เองอ่าครับ



 

อยากทราบวิธีหาว่าอยู่สัปดาห์ที่เท่าไหร่ โดยกำหนดวันเริ่มต้นและวันที่ เองอ่าครับ

 



Topic : 107309



โพสกระทู้ ( 141 )
บทความ ( 0 )



สถานะออฟไลน์




ตามหัวข้อเลยครับ เช่นเริ่มต้นที่วันที่ 01/03/2557

input
06/04/2557

output
6



Tag : PHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2014-03-28 15:55:45 By : dreamt256 View : 5079 Reply : 18
 

 

No. 1



โพสกระทู้ ( 2,249 )
บทความ ( 5 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook Hi5 Blogger

Code (PHP)
echo $week = date("W", strtotime('2014-03-28')); //13







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-28 17:14:30 By : Manussawin
 


 

No. 2



โพสกระทู้ ( 141 )
บทความ ( 0 )



สถานะออฟไลน์


อันนั้นมันของปี ไม่ใช่หรอครับ คือผมอยากกำหนดวันเริ่มนับเองอ่าครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-28 22:34:09 By : dreamt256
 

 

No. 3



โพสกระทู้ ( 141 )
บทความ ( 0 )



สถานะออฟไลน์


ได้แล้วนะครับ ใช้โค้ดนี้ครับ [โจทย์นี้ช่างยากเหลือ] - -
Code (PHP)
function numWeek($strStartDate,$strEndDate){//2012-02-01

	$intMonday = 0;
	$intOther = 0;
	$intRound = array();
	$i = 0;

	while (strtotime($strStartDate) <= strtotime($strEndDate)) {
		$DayOfWeek = date("w", strtotime($strStartDate));
		if($DayOfWeek == 1)  // 1 = monday
		{
			$intMonday++;
			$intOther = 0;
			$intRound[$i] = 1;
		}else{
			$intOther++;
		}

		$strStartDate = date ("Y-m-d", strtotime("+1 day", strtotime($strStartDate)));
	}
	if($intOther > "0" && $intRound[0] =! "1"){
		$intMonday++;
	}
	$i++;
	return $intMonday;
}



ประวัติการแก้ไข
2014-03-29 09:44:55
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-29 01:40:52 By : dreamt256
 


 

No. 4

Guest


ความถูกต้อง/สิ่งที่เราต้องการ มันคือความถูกต้อง แต่มันไม่สามารถครอบคลุมในทุกฯ กรณี ได้ครับ

คำแนะนำของคุณ Manussawin น่าจะถูกต้องมากที่สุดครับ (ในสภาพแวดล้อมที่เท่าเท่ากัน)
Code (PHP)
echo $week = date("W", strtotime('2014-03-28')); //13

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 12:29:33 By : love9713
 


 

No. 5

Guest


ผมยกคำถามง่ายง่ายครับ เพื่อประกอบความเข้าใจ "ในหนึ่งปีมีทั้งหมดกี่วัน"?
--- พระเจ้ายังอุทานว่า "สิ่งนี้ฉันไม่ได้สร้างขึ้นมา"


แต่ถ้าถามว่า "ปีนี้มีจำนวนวันทั้งหมดกี่วัน"
--- มนุษย์ยังพอให้คำตอบได้ (น่าจะถูกต้อง)
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 12:37:05 By : love9713
 


 

No. 6

Guest


ผมเล่านิทานให้ฟังอีกเรื่องหนึ่งครับ

กระต่าย : วันแรกของปี คือวันที่ 1-xx-xxxx หมายความว่า xx, xxxx คืออะไรก็ได้ แต่ไม่ใช่ทั้งหมด
เต่า : วันแรกของปี คือวันที่ 2-xx-xxxxx มันให้ความหมายว่า วันแรกของฉันมันก็แตกต่างกับเธอแล้ว


แล้วเราจะนับวันอย่างไร?ครับ
แล้วเราจะนับสัปดาห์อย่างไร?ครับ
แล้วเราจะนับปีอย่างไร?ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 12:48:20 By : love9713
 


 

No. 7

Guest


ตอบความคิดเห็นที่ : 3 เขียนโดย : dreamt256 เมื่อวันที่ 2014-03-29 01:40:52
รายละเอียดของการตอบ ::
อันนี้ถือว่าใช้ได้แล้วครับ หรืออยากจะพูดว่ายอดเยี่ยมก็ไม่ได้มีอะไรเสียหาย? ครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 12:53:37 By : love9713
 


 

No. 8

Guest


ผมหวังว่าคุณจะกลับมาอ่านอีกครั้งหนึ่ง

Code
ตามหัวข้อเลยครับ เช่นเริ่มต้นที่วันที่ 01/03/2557 input 06/04/2557 output 6 Or output 5 Or 7 or มากกว่านั้นก็ได้/น้อยกว่านั้นก็ได้ อยู่ที่ความเข้าใจ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 14:18:32 By : love9713
 


 

No. 9



โพสกระทู้ ( 141 )
บทความ ( 0 )



สถานะออฟไลน์


กลับมาอ่านแล้วครับ เอ่อ คือว่า คุณต้องการจะสื่ออะไรหรอครับ ???
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 17:37:47 By : dreamt256
 


 

No. 10

Guest


คุณลองกลับไปอ่าน #NO 4 - #NO 8 สมมุติว่าคุณเข้าใจ ผมจะดีใจมากกว่าที่คุณกลับมาอ่านมันอีกครั้งหนึ่ง ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 19:12:22 By : love9713
 


 

No. 11

Guest


ผมเอามาจาก Internet (www.SqlCentral.com) ผมเพียงแค่เก็บรวบรวมเอาไว้ (กันลืม)

Code (SQL)
SET DATEFIRST 7 -- Sunday
SELECT @@DATEFIRST

SET DATEFIRST 1 -- Monday

DECLARE @startDate DATE = '2014-01-01', @endDate DATE = '2014-12-31';

--CROSS JOIN
;WITH t1(N) AS (SELECT N FROM (VALUES(1),(1)) TableValueExpression(N)), -- 2 Rows
      t2(N) AS (SELECT 1 FROM t1 x, t1 y), -- 4 Rows (2*2)
      t3(N) AS (SELECT 1 FROM t2 x, t2 y), -- 16 Rows (4*4)
      t4(N) AS (SELECT 1 FROM t3 x, t3 y), -- 256 Rows (16*16)
      t5(N) AS (SELECT 1 FROM t4 x, t4 y), -- 65,536 Rows (256*256)
      tally(N) AS (SELECT 0 UNION ALL
                  SELECT TOP (DATEDIFF(WEEK, @startDate, @endDate)) -- Limit the result-set straight up front
                  ROW_NUMBER() OVER(ORDER BY (SELECT NULL))
                  FROM t5 x, t5 y) -- 4,294,967,296 Rows (65,536*65,536)
SELECT N + 1  AS WeekNo,
CASE WHEN DATEADD(WEEK, DATEDIFF(WEEK, '1900-01-02', DATEADD(WEEK, N, @startDate)), '1900-01-02') < @startDate 
     THEN @startDate
     ELSE DATEADD(WEEK, DATEDIFF(WEEK, '1900-01-02', DATEADD(WEEK,N , @startDate)), '1900-01-02') END AS weekStart,
CASE WHEN DATEADD(WEEK, DATEDIFF(WEEK, '1900-01-08', DATEADD(WEEK, N + 1, @startDate)), '1900-01-08') > @endDate 
     THEN @endDate
     ELSE DATEADD(WEEK, DATEDIFF(WEEK, '1900-01-08', DATEADD(WEEK, N + 1, @startDate)), '1900-01-08') END AS weekEnd
FROM tally;

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 19:32:55 By : love9713
 


 

No. 12

Guest


ตัวอย่าง #NO 11

wk_001
...
...
...
สัปดาห์ที่ 52 -53 (ประมาณ)
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 19:36:17 By : love9713
 


 

No. 13

Guest



ีมีมาก สุขมาก จน ทุกข์มาก



ผมมี เศษเงิน เหลืออยู่ 5 ล้านบาท (ห้าล้านบาท) 2014-03-30
ผมควรจะทำอะไร?
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 21:56:29 By : love9713
 


 

No. 14



โพสกระทู้ ( 141 )
บทความ ( 0 )



สถานะออฟไลน์


เอ่อ ขอบคุณ คุณมากเลยนะครับ ตอนนี้ผมใช้สคริปผมอยู่ก็ถือว่าโอเคแล้วนะครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-30 22:14:58 By : dreamt256
 


 

No. 15

Guest


ตอบความคิดเห็นที่ : 14 เขียนโดย : dreamt256 เมื่อวันที่ 2014-03-30 22:14:58
รายละเอียดของการตอบ ::
อะไรที่ไม่ได้มาจาก "เสแสร้ง" สรรพสิ่งเหล่านี้ ล้วนเป็นคุณ โดยที่เราไม่ต้องไปรอคอยผลลัพธ์ของมัน


ผมก็เรียนรู้ไปพร้อมฯกับคุณครับ อทิเช่น Framework PHP, YII, Codeigniter, etc...
จะว่าไปแล้ว ผม จนมากกว่าคุณเสียอีก ครับ



[x] ผมรู้สึกว่า คุณเป็นลูกหลานของผม และคุณเป็นครูของผม ผมรู้สึกเช่นนี้จริงฯครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-31 08:40:50 By : love9713
 


 

No. 16

Guest


อันไหนที่มีผ่านมามาตอบ ความน่าตอบจะลดลง 80%

Code (PHP)
$start = new DateTime('2014-03-01');
$end = new DateTime('2014-04-06');

$week = intval($end->format('W')) - intval($start->format('W'));

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-31 09:21:49 By : ห้ามตอบเกินวันละ 2 กระทู้
 


 

No. 17

Guest


ตอบความคิดเห็นที่ : 16 เขียนโดย : ห้ามตอบเกินวันละ 2 กระทู้ เมื่อวันที่ 2014-03-31 09:21:49
รายละเอียดของการตอบ ::
ผมไม่เคยคิดจะเกลียดคุณ แม้แต่ครั้งเดียว ครับ
ผมยังคิดถึงคุณเสมอ



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-31 09:31:33 By : love9713
 


 

No. 18

Guest


ตอบความคิดเห็นที่ : 16 เขียนโดย : ห้ามตอบเกินวันละ 2 กระทู้ เมื่อวันที่ 2014-03-31 09:21:49
รายละเอียดของการตอบ ::
ผมสงสัยว่า ทำไมต้องเป็นวันที่ 2 หรือ วันที่ 8 ของแต่ละเดือน/ปี
เพื่อที่จะนับอะไรบางอย่าง อทิเช่น สัปดาห์ เป็นต้น


ขอบคุณครับ น้องเมียและพี่เมีย































































ของผม
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-03-31 09:55:28 By : love9713
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : อยากทราบวิธีหาว่าอยู่สัปดาห์ที่เท่าไหร่ โดยกำหนดวันเริ่มต้นและวันที่ เองอ่าครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 00
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่