ส่งกลับ ตัวแปร (ยาว) ที่ระบุตำแหน่งของการปรากฎครั้งแรกของสตริงหนึ่งภายในสตริงอื่น
ไวยากรณ์
InStr([start, ] string1, string2 [, compare ] )
ไวยากรณ์ของฟังก์ชัน InStr มีอาร์กิวเมนต์ดังนี้
| อาร์กิวเมนต์ | คำอธิบาย |
|---|---|
| เริ่ม | ไม่จำเป็น นิพจน์ตัวเลขที่ตั้งค่าตําแหน่งเริ่มต้นสําหรับการค้นหาแต่ละครั้ง ถ้าไม่ระบุไว้ การค้นหาจะเริ่มต้นที่ตําแหน่งอักขระแรก หาก start มี Null จะเกิดข้อผิดพลาดขึ้น จําเป็นต้องมีอาร์กิวเมนต์ start ถ้ามีการระบุ compare |
| สตริง 1 | จำเป็น นิพจน์สตริงที่กําลังค้นหา |
| สตริง 2 | จำเป็น นิพจน์สตริงที่ค้นหา |
| เปรียบ เทียบ | ไม่จำเป็น ระบุชนิดของการเปรียบเทียบสตริง หาก compare เป็น Null จะเกิดข้อผิดพลาดขึ้น ถ้าละ compare การตั้งค่า OptionCompare จะกําหนดชนิดของการเปรียบเทียบ ระบุ LCID (LocaleID) ที่ถูกต้องเพื่อใช้กฎเฉพาะตําแหน่งที่ตั้งในการเปรียบเทียบ |
เคล็ดลับ
ตัวสร้างนิพจน์มี IntelliSense เพื่อให้คุณสามารถดูอาร์กิวเมนต์ที่นิพจน์ของคุณจําเป็นต้องใช้
การตั้งค่า
การตั้งค่าอาร์กิวเมนต์ เปรียบเทียบ มีดังนี้
| คง | ค่า | คำอธิบาย |
|---|---|---|
| vbUseCompareOption | -1 | ทําการเปรียบเทียบโดยใช้การตั้งค่าคําสั่งเปรียบเทียบตัวเลือก |
| vbBinaryCompare | 0 | ทําการเปรียบเทียบแบบไบนารี |
| vbTextCompare | 1 | ทําการเปรียบเทียบเป็นข้อความ |
ส่งกลับค่า
| If | InStr ส่งกลับค่า |
|---|---|
| สตริง 1 มีความยาวเป็นศูนย์ | 0 |
| สตริง 1 เป็น Null | Null |
| สตริง 2 มีความยาวเป็นศูนย์ | เริ่ม |
| สตริง 2 เป็น Null | Null |
| ไม่พบสตริง 2 | 0 |
| สตริง 2 จะพบภายในสตริง 1 | ตําแหน่งที่พบรายการที่ตรงกัน |
| เริ่ม > สตริง 2 | 0 |
ข้อสังเกต
ฟังก์ชัน InStrB จะใช้กับข้อมูลไบต์ที่อยู่ในสตริง แทนที่จะส่งกลับตําแหน่งอักขระของเหตุการณ์แรกของสตริงหนึ่งภายในอีกสตริงหนึ่ง InStrB จะส่งกลับตําแหน่งไบต์
ตัวอย่าง
ใช้ฟังก์ชัน InStr ในนิพจน์ คุณสามารถใช้ InStr ได้ทุกที่ที่คุณสามารถใช้นิพจน์ได้ ตัวอย่างเช่น ถ้าคุณต้องการค้นหาตําแหน่งของจุดแรก (.) ในเขตข้อมูลที่มีที่อยู่ IP (ชื่อ IPAddress) คุณสามารถใช้ InStr เพื่อค้นหาได้ ดังนี้
InStr(1,[IPAddress],".")
ฟังก์ชัน InStr จะตรวจสอบแต่ละค่าในเขตข้อมูล IPAddress และส่งกลับตําแหน่งของคาบเวลาแรก ดังนั้น ถ้าส่วนแรกของที่อยู่ IP คือ 10 ฟังก์ชันจะส่งกลับค่า 3
จากนั้นคุณสามารถใช้ฟังก์ชันอื่นๆ ที่ทํางานบนผลลัพธ์ของฟังก์ชัน InStr เพื่อแยกส่วนของที่อยู่ IP ที่มาก่อนช่วงเวลาแรกดังนี้:
Left([IPAddress],(InStr(1,[IPAddress],".")-1))
ในตัวอย่างนี้ InStr(1,[IPAddress],".") ส่งกลับตําแหน่งของคาบเวลาแรก การลบ 1 จะกําหนดจํานวนอักขระที่อยู่ก่อนหน้าจุดแรก ซึ่งในกรณีนี้คือ 2 จากนั้น ฟังก์ชัน Left จะแยกอักขระจํานวนมากจากส่วนซ้ายของเขตข้อมูล IPAddress ซึ่งจะส่งกลับค่า 10
ใช้ InStr ในโค้ด VBA
หมายเหตุ
ตัวอย่างต่อไปนี้จะสาธิตการใช้ฟังก์ชันนี้ในโมดูล Visual Basic for Applications (VBA)
ตัวอย่างนี้ใช้ฟังก์ชัน InStr เพื่อส่งกลับตําแหน่งของการปรากฏครั้งแรกของสตริงหนึ่งภายในอีกสตริงหนึ่ง
Dim SearchString, SearchChar, MyPos
SearchString ="XXpXXpXXPXXP" ' String to search in.
SearchChar = "P" ' Search for "P".
' A textual comparison starting at position 4. Returns 6.
MyPos = Instr(4, SearchString, SearchChar, 1)
' A binary comparison starting at position 1. Returns 9.
MyPos = Instr(1, SearchString, SearchChar, 0)
' Comparison is binary by default
' (last argument is omitted).
MyPos = Instr(SearchString, SearchChar) ' Returns 9.
MyPos = Instr(1, SearchString, "W") ' Returns 0.