ไปยังเนื้อหาหลัก

จะสร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขที่กำหนดสองตัวใน Excel ได้อย่างไร

ใน Excel คุณเคยพยายามแสดงรายการจำนวนเฉพาะทั้งหมดระหว่างตัวเลขสองตัวหรือไม่? บทความนี้ฉันจะพูดถึงวิธีการที่น่าสนใจในการจัดการกับงานนี้

สร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขที่กำหนดสองตัวด้วยสูตร

สร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขสองตัวที่กำหนดด้วย User Defined Function


ลูกศรสีฟ้าฟองขวา สร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขที่กำหนดสองตัวด้วยสูตร

รวม กำหนดชื่อ ฟังก์ชันและสูตรคุณสามารถแสดงรายการหรือสร้างจำนวนเฉพาะทั้งหมดระหว่างจำนวนเฉพาะสองจำนวนได้ โปรดดำเนินการดังนี้:

1. โปรดสร้างชื่อช่วงแรกโดยคลิก สูตร > ชื่อผู้จัดการ, และใน ชื่อผู้จัดการ คลิกตกลง ใหม่ ปุ่มดูภาพหน้าจอ:

doc รายการหมายเลขเฉพาะ 1

2. ใน ชื่อใหม่ ในกลองโตตอบ Name กล่องข้อความกรุณาใส่ RNG เป็นชื่อช่วงจากนั้นป้อนสูตรนี้: = ROW (ทางอ้อม (Sheet1! $ B $ 1 & ":" & Sheet1! $ B $ 2)) (Sheet1 คือแผ่นงานปัจจุบันของคุณที่คุณใช้ B1 และ B2 คือหมายเลขเริ่มต้นและหมายเลขสิ้นสุดที่คุณระบุ) ลงในไฟล์ อ้างถึง กล่องข้อความจากนั้นคลิก OK เพื่อกลับไปยังกล่องโต้ตอบเดิม ดูภาพหน้าจอ:

doc รายการหมายเลขเฉพาะ 2

3. ไปที่การคลิก ใหม่ เพื่อสร้างชื่อช่วงอื่นในไฟล์ ชื่อใหม่ กล่องโต้ตอบป้อนชื่อ สำคัญ เข้าไปใน Name กล่องข้อความจากนั้นป้อนสูตรนี้: =SMALL(IF(MMULT(--(IF(rng>TRANSPOSE(rng-Sheet1!$B$1+2),MOD(rng,(rng>TRANSPOSE(rng-Sheet1!$B$1+2))*TRANSPOSE(rng-Sheet1!$B$1+2)))=0),rng-Sheet1!$B$1+2)=0,rng),ROW(INDIRECT("1:"&Sheet1!$B$2))) (RNG คือชื่อช่วงแรกที่คุณสร้างในขั้นตอนที่ 2) ลงในไฟล์ อ้างถึง กล่องข้อความดูภาพหน้าจอ:

doc รายการหมายเลขเฉพาะ 3

4. จากนั้นคลิก OK และปิดกล่องโต้ตอบและเลือกหนึ่งคอลัมน์ที่คุณต้องการแสดงรายการจำนวนเฉพาะทั้งหมดแล้วป้อนสูตรนี้: = IFERROR (เฉพาะ, "")(สำคัญ คือชื่อช่วงที่คุณสร้างในขั้นตอนที่ 3) ลงในแถบสูตรแล้วกด CTRL+SHIFT+ENTER คีย์เข้าด้วยกันหมายเลขเฉพาะทั้งหมดระหว่างตัวเลขสองตัวที่ระบุจะแสดงเป็นภาพหน้าจอต่อไปนี้:

doc รายการหมายเลขเฉพาะ 4


ลูกศรสีฟ้าฟองขวา สร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขสองตัวที่กำหนดด้วย User Defined Function

หากวิธีแรกค่อนข้างยากคุณสามารถใช้ a ฟังก์ชันที่ผู้ใช้กำหนด เพื่อแก้ปัญหา

1. กด ALT + F11 คีย์เพื่อเปิด Microsoft Visual Basic สำหรับแอปพลิเคชัน หน้าต่าง

2. คลิก สิ่งที่ใส่เข้าไป > โมดูลและวางรหัสต่อไปนี้ในไฟล์ โมดูล หน้าต่าง.

รหัส VBA: สร้างจำนวนเฉพาะทั้งหมดระหว่างตัวเลขเฉพาะสองตัว:

Function PRIME(St, En As Long)
'Updateby Extendoffice 20160613
Dim num As String
For n = St To En
    For m = 2 To n - 1
        If n Mod m = 0 Then GoTo 20:
    Next m
    num = num & n & ","
20:
Next n
PRIME = num
End Function

3. จากนั้นบันทึกและปิดรหัสนี้กลับไปที่แผ่นงานโปรดป้อนสูตรนี้: = นายก (10,100) (10 คือหมายเลขเริ่มต้นและ 100 คือหมายเลขต่อท้ายที่คุณต้องการรับจำนวนเฉพาะระหว่างคุณสามารถเปลี่ยนได้ตามต้องการ) จากนั้นกด เข้าสู่ และจำนวนเฉพาะทั้งหมดจะแสดงในเซลล์เดียวดูภาพหน้าจอ:

doc รายการหมายเลขเฉพาะ 5

สุดยอดเครื่องมือเพิ่มผลผลิตในสำนักงาน

🤖 Kutools AI ผู้ช่วย: ปฏิวัติการวิเคราะห์ข้อมูลโดยยึดตาม: การดำเนินการที่ชาญฉลาด   |  สร้างรหัส  |  สร้างสูตรที่กำหนดเอง  |  วิเคราะห์ข้อมูลและสร้างแผนภูมิ  |  เรียกใช้ฟังก์ชัน Kutools...
คุณสมบัติยอดนิยม: ค้นหา เน้น หรือระบุรายการที่ซ้ำกัน   |  ลบแถวว่าง   |  รวมคอลัมน์หรือเซลล์โดยไม่สูญเสียข้อมูล   |   รอบโดยไม่มีสูตร ...
การค้นหาขั้นสูง: VLookup หลายเกณฑ์    VLookup หลายค่า  |   VLookup ข้ามหลายแผ่น   |   การค้นหาที่ไม่ชัดเจน ....
รายการแบบเลื่อนลงขั้นสูง: สร้างรายการแบบหล่นลงอย่างรวดเร็ว   |  รายการแบบหล่นลงขึ้นอยู่กับ   |  เลือกหลายรายการแบบหล่นลง ....
ผู้จัดการคอลัมน์: เพิ่มจำนวนคอลัมน์เฉพาะ  |  ย้ายคอลัมน์  |  สลับสถานะการมองเห็นของคอลัมน์ที่ซ่อนอยู่  |  เปรียบเทียบช่วงและคอลัมน์ ...
คุณสมบัติเด่น: กริดโฟกัส   |  มุมมองการออกแบบ   |   บาร์สูตรใหญ่    สมุดงานและตัวจัดการชีต   |  ห้องสมุดทรัพยากร (ข้อความอัตโนมัติ)   |  เลือกวันที่   |  รวมแผ่นงาน   |  เข้ารหัส/ถอดรหัสเซลล์    ส่งอีเมลตามรายการ   |  ซุปเปอร์ฟิลเตอร์   |   ตัวกรองพิเศษ (กรองตัวหนา/ตัวเอียง/ขีดทับ...) ...
ชุดเครื่องมือ 15 อันดับแรก12 ข้อความ เครื่องมือ (เพิ่มข้อความ, ลบอักขระ, ... )   |   50 + แผนภูมิ ประเภท (แผนภูมิ Gantt, ... )   |   40+ ใช้งานได้จริง สูตร (คำนวณอายุตามวันเกิด, ... )   |   19 การแทรก เครื่องมือ (ใส่ QR Code, แทรกรูปภาพจากเส้นทาง, ... )   |   12 การแปลง เครื่องมือ (ตัวเลขเป็นคำ, การแปลงสกุลเงิน, ... )   |   7 ผสานและแยก เครื่องมือ (แถวรวมขั้นสูง, แยกเซลล์, ... )   |   ... และอื่น ๆ

เพิ่มพูนทักษะ Excel ของคุณด้วย Kutools สำหรับ Excel และสัมผัสประสิทธิภาพอย่างที่ไม่เคยมีมาก่อน Kutools สำหรับ Excel เสนอคุณสมบัติขั้นสูงมากกว่า 300 รายการเพื่อเพิ่มประสิทธิภาพและประหยัดเวลา  คลิกที่นี่เพื่อรับคุณสมบัติที่คุณต้องการมากที่สุด...

รายละเอียด


แท็บ Office นำอินเทอร์เฟซแบบแท็บมาที่ Office และทำให้งานของคุณง่ายขึ้นมาก

  • เปิดใช้งานการแก้ไขและอ่านแบบแท็บใน Word, Excel, PowerPoint, ผู้จัดพิมพ์, Access, Visio และโครงการ
  • เปิดและสร้างเอกสารหลายรายการในแท็บใหม่ของหน้าต่างเดียวกันแทนที่จะเป็นในหน้าต่างใหม่
  • เพิ่มประสิทธิภาพการทำงานของคุณ 50% และลดการคลิกเมาส์หลายร้อยครั้งให้คุณทุกวัน!
Comments (3)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
Sub generateprimenumbersbetween3() starting_number = 1 'input value here last_number = 10000 'input value here primenumbers = "" For a = starting_number To last_number c = a For b = 2 To c If a Mod b = 0 And c b Then Exit For Else If b = c Then primenumbers = primenumbers & " " & a Exit For Else If Round(a / (b + 1)) + 1 > b Then c = Round(a / (b + 1)) + 1 End If End If End If Next b Next a MsgBox primenumbers End Sub Function PRIMENUMBERSBETWEEN3(starting_number, last_number) primenumbers = "" For a = starting_number To last_number c = a For b = 2 To c If a Mod b = 0 And c b Then Exit For Else If b = c Then primenumbers = primenumbers & " " & a Exit For Else If Round(a / (b + 1)) + 1 > b Then c = Round(a / (b + 1)) + 1 End If End If End If Next b Next a PRIMENUMBERSBETWEEN3 = primenumbers End Function Sub ISPRIME3() number_to_be_checked = 15485863 'input value here c = number_to_be_checked For b = 2 To c If number_to_be_checked Mod b = 0 And c b Then MsgBox "Not Prime. Divisible by " & b Exit Sub Else If b = c Then MsgBox "Prime" Exit Sub Else If Round(number_to_be_checked / (b + 1)) + 1 > b Then c = Round(number_to_be_checked / (b + 1)) + 1 End If End If End If Next b End Sub
This comment was minimized by the moderator on the site
Sub generateprimenumbersbetween() starting_number = 1 'input value here last_number = 2000 'input value here primenumbers = "" For a = starting_number To last_number For b = 2 To a If a - b * Int(a / b) = 0 And a b Then Exit For Else If a = b Then primenumbers = primenumbers & " " & a End If End If Next b Next a MsgBox primenumbers End Sub Function primenumbersbetween(starting_number, last_number) primenumbers = "" For a = starting_number To last_number For b = 2 To a If a - b * Int(a / b) = 0 And a b Then Exit For Else If a = b Then primenumbers = primenumbers & " " & a End If End If Next b Next a primenumbersbetween = primenumbers End Function 'to check if a number is prime Sub ISPRIME() number_to_be_checked = 102 'input value here For b = 2 To number_to_be_checked If number_to_be_checked - b * Int(number_to_be_checked / b) = 0 And _ number_to_be_checked b Then MsgBox "Not Prime. Divisible by " & b Exit Sub Else If number_to_be_checked = b Then MsgBox "Prime" End If End If Next b End Sub 'to check if a number is prime Function ISPRIME2(number_to_be_checked) For b = 2 To number_to_be_checked If number_to_be_checked - b * Int(number_to_be_checked / b) = 0 And _ number_to_be_checked b Then ISPRIME2 = "Not Prime. Divisible by " & b Exit Function Else If number_to_be_checked = b Then ISPRIME2 = "Prime" End If End If Next b End Function
This comment was minimized by the moderator on the site
<p>



End Sub

</p>
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations