Note: The other languages of the website are Google-translated. Back to English
English English

วิธีการสะกดหรือแปลงตัวเลขเป็นคำภาษาอังกฤษใน Excel

สมมติว่าคุณมีตัวเลขราคาจำนวนมากและตอนนี้คุณต้องแปลงหรือสะกดให้เป็นสตริงข้อความ ตัวอย่างเช่นแปลง $ 123.55 เป็นคำภาษาอังกฤษ หนึ่งร้อยยี่สิบสามดอลลาร์และห้าสิบห้าเซนต์. ใน Excel ไม่มีสิ่งอำนวยความสะดวกที่มีประสิทธิภาพในการแก้ปัญหานี้ แต่ใช้รหัส VBA ที่ยาวและซับซ้อน ในบทความนี้ฉันจะแนะนำวิธีการจัดการกับมัน

สะกดหรือแปลงตัวเลขเป็นคำภาษาอังกฤษด้วยรหัส VBA

สะกดหรือแปลงตัวเลขเป็นคำภาษาอังกฤษด้วย Kutools for Excel


สะกดหรือแปลงตัวเลขเป็นคำภาษาอังกฤษด้วยรหัส VBA

รหัส VBA แบบยาวต่อไปนี้สามารถช่วยคุณในการสะกดตัวเลขลงในสตริงข้อความ ดำเนินการดังต่อไปนี้:

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

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

VBA: สะกดตัวเลขสกุลเงินเป็นคำภาษาอังกฤษใน Excel

Function SpellNumberToEnglish(ByVal pNumber)
'Updateby20131113
Dim Dollars, Cents
arr = Array("", "", " Thousand ", " Million ", " Billion ", " Trillion ")
pNumber = Trim(Str(pNumber))
xDecimal = InStr(pNumber, ".")
If xDecimal > 0 Then
    Cents = GetTens(Left(Mid(pNumber, xDecimal + 1) & "00", 2))
    pNumber = Trim(Left(pNumber, xDecimal - 1))
End If
xIndex = 1
Do While pNumber <> ""
    xHundred = ""
    xValue = Right(pNumber, 3)
    If Val(xValue) <> 0 Then
        xValue = Right("000" & xValue, 3)
        If Mid(xValue, 1, 1) <> "0" Then
            xHundred = GetDigit(Mid(xValue, 1, 1)) & " Hundred "
        End If
        If Mid(xValue, 2, 1) <> "0" Then
            xHundred = xHundred & GetTens(Mid(xValue, 2))
        Else
            xHundred = xHundred & GetDigit(Mid(xValue, 3))
        End If
    End If
    If xHundred <> "" Then
        Dollars = xHundred & arr(xIndex) & Dollars
    End If
    If Len(pNumber) > 3 Then
        pNumber = Left(pNumber, Len(pNumber) - 3)
    Else
        pNumber = ""
    End If
    xIndex = xIndex + 1
Loop
Select Case Dollars
    Case ""
        Dollars = "No Dollars"
    Case "One"
        Dollars = "One Dollar"
    Case Else
        Dollars = Dollars & " Dollars"
End Select
Select Case Cents
    Case ""
        Cents = " and No Cents"
    Case "One"
        Cents = " and One Cent"
    Case Else
        Cents = " and " & Cents & " Cents"
End Select
SpellNumberToEnglish = Dollars & Cents
End Function
Function GetTens(pTens)
Dim Result As String
Result = ""
If Val(Left(pTens, 1)) = 1 Then
    Select Case Val(pTens)
        Case 10: Result = "Ten"
        Case 11: Result = "Eleven"
        Case 12: Result = "Twelve"
        Case 13: Result = "Thirteen"
        Case 14: Result = "Fourteen"
        Case 15: Result = "Fifteen"
        Case 16: Result = "Sixteen"
        Case 17: Result = "Seventeen"
        Case 18: Result = "Eighteen"
        Case 19: Result = "Nineteen"
        Case Else
    End Select
Else
Select Case Val(Left(pTens, 1))
    Case 2: Result = "Twenty "
    Case 3: Result = "Thirty "
    Case 4: Result = "Forty "
    Case 5: Result = "Fifty "
    Case 6: Result = "Sixty "
    Case 7: Result = "Seventy "
    Case 8: Result = "Eighty "
    Case 9: Result = "Ninety "
    Case Else
End Select
Result = Result & GetDigit(Right(pTens, 1))
End If
GetTens = Result
End Function
Function GetDigit(pDigit)
Select Case Val(pDigit)
    Case 1: GetDigit = "One"
    Case 2: GetDigit = "Two"
    Case 3: GetDigit = "Three"
    Case 4: GetDigit = "Four"
    Case 5: GetDigit = "Five"
    Case 6: GetDigit = "Six"
    Case 7: GetDigit = "Seven"
    Case 8: GetDigit = "Eight"
    Case 9: GetDigit = "Nine"
    Case Else: GetDigit = ""
End Select
End Function

3. จากนั้นบันทึกรหัสและกลับไปที่แผ่นงานในเซลล์ B2 ที่อยู่ติดกันให้ป้อนสูตร = SpellNumberToEnglish (A1)ดูภาพหน้าจอ:

4. จากนั้นกด เข้าสู่ และเลือกเซลล์ B2 จากนั้นลากจุดจับเติมไปยังช่วงที่มีสูตรนี้ตามที่คุณต้องการ และตัวเลขสกุลเงินทั้งหมดถูกสะกดเป็นคำภาษาอังกฤษ ดูภาพหน้าจอ:

หมายเหตุ: เนื่องจากเป็นสูตรเมื่อคุณต้องการคัดลอกและวางโปรดวางเป็นค่า


สะกดหรือแปลงตัวเลขเป็นคำภาษาอังกฤษด้วย Kutools for Excel

บางทีโค้ดยาว ๆ ข้างต้นอาจทำให้คุณเป็นบ้าได้โปรดอย่ากังวลที่นี่ฉันสามารถให้วิธีแก้ปัญหาที่ง่ายและรวดเร็ว กับ Kutools สำหรับ Excel's ตัวเลขเป็นคำ คุณสามารถแปลงตัวเลขเป็นสตริงข้อความได้อย่างรวดเร็วและสะดวก

Kutools สำหรับ Excel- รวมเครื่องมือที่มีประโยชน์มากกว่า 300 รายการสำหรับ Excel ทดลองใช้ฟรี 30 วันเต็มไม่ต้องใช้บัตรเครดิต! Get It Now

1. เลือกหมายเลขช่วงที่คุณต้องการสะกดแล้วคลิก Kutools > เนื้อหา > ตัวเลขเป็นคำ.
doc kutools จำนวนต่อคำ 1

2. ในกล่องโต้ตอบที่โผล่ขึ้นมาให้เลือก English จาก ภาษา. และคุณสามารถดูผลลัพธ์จากด้านขวา ดูตัวอย่าง บานหน้าต่าง ดูภาพหน้าจอ:
doc kutools จำนวนต่อคำ 2

3. จากนั้นคลิก Ok or ใช้. และจำนวนราคาทั้งหมดได้ถูกแปลงเป็นสตริงข้อความในช่วงเดิม
doc kutools จำนวนต่อคำ 3

หมายเหตุ: หากคุณเพียงต้องการแปลงตัวเลขเป็นคำภาษาอังกฤษ (ไม่ใช่สกุลเงิน) โปรดตรวจสอบ ไม่ได้แปลงเป็นสกุลเงิน ช่องทำเครื่องหมาย
doc kutools จำนวนต่อคำ 3 doc kutools จำนวนต่อคำ 3

คุณสมบัติที่ยอดเยี่ยมของ ตัวเลขเป็นคำ สามารถแปลตัวเลขสกุลเงินเป็นข้อความของสกุลเงินเป็นภาษาอังกฤษหรือภาษาจีนได้อย่างง่ายดายเช่นแปล 32.01 เป็น "สามสิบสองดอลลาร์และหนึ่งเซ็นต์" หรือ "叁拾贰元零壹分" ทดลองใช้ฟรี!

การสาธิต: สะกดตัวเลขสกุลเงินเป็นคำภาษาอังกฤษ


เครื่องมือเพิ่มประสิทธิภาพการทำงานในสำนักงานที่ดีที่สุด

Kutools สำหรับ Excel ช่วยแก้ปัญหาส่วนใหญ่ของคุณและเพิ่มผลผลิตของคุณได้ถึง 80%

  • นำมาใช้ใหม่: ใส่อย่างรวดเร็ว สูตรที่ซับซ้อนแผนภูมิ และสิ่งที่คุณเคยใช้มาก่อน เข้ารหัสเซลล์ ด้วยรหัสผ่าน; สร้างรายชื่อผู้รับจดหมาย และส่งอีเมล ...
  • ซุปเปอร์ฟอร์มูล่าบาร์ (แก้ไขข้อความและสูตรหลายบรรทัดได้อย่างง่ายดาย); การอ่านเค้าโครง (อ่านและแก้ไขเซลล์จำนวนมากได้อย่างง่ายดาย); วางลงในช่วงที่กรองแล้ว...
  • ผสานเซลล์ / แถว / คอลัมน์ โดยไม่สูญเสียข้อมูล แยกเนื้อหาของเซลล์ รวมแถว / คอลัมน์ที่ซ้ำกัน... ป้องกันเซลล์ซ้ำ; เปรียบเทียบช่วง...
  • เลือกซ้ำหรือไม่ซ้ำ แถว; เลือกแถวว่าง (เซลล์ทั้งหมดว่างเปล่า); Super Find และ Fuzzy Find ในสมุดงานจำนวนมาก สุ่มเลือก ...
  • สำเนาถูกต้อง หลายเซลล์โดยไม่เปลี่ยนการอ้างอิงสูตร สร้างการอ้างอิงอัตโนมัติ ถึงหลายแผ่น ใส่สัญลักษณ์แสดงหัวข้อย่อย, กล่องกาเครื่องหมายและอื่น ๆ ...
  • แยกข้อความ, เพิ่มข้อความ, ลบตามตำแหน่ง, ลบ Space; สร้างและพิมพ์ผลรวมย่อยของเพจ แปลงระหว่างเนื้อหาของเซลล์และความคิดเห็น...
  • ซุปเปอร์ฟิลเตอร์ (บันทึกและใช้โครงร่างตัวกรองกับแผ่นงานอื่น ๆ ); การเรียงลำดับขั้นสูง ตามเดือน / สัปดาห์ / วันความถี่และอื่น ๆ ตัวกรองพิเศษ โดยตัวหนาตัวเอียง ...
  • รวมสมุดงานและแผ่นงาน; ผสานตารางตามคอลัมน์สำคัญ แยกข้อมูลออกเป็นหลายแผ่น; Batch แปลง xls, xlsx และ PDF...
  • คุณสมบัติที่ทรงพลังมากกว่า 300 รายการ. รองรับ Office / Excel 2007-2019 และ 365 รองรับทุกภาษา ใช้งานง่ายในองค์กรหรือองค์กรของคุณ ทดลองใช้ฟรี 30 วันเต็ม รับประกันคืนเงิน 60 วัน
kte แท็บ 201905

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

  • เปิดใช้งานการแก้ไขและอ่านแบบแท็บใน Word, Excel, PowerPoint, ผู้จัดพิมพ์, Access, Visio และโครงการ
  • เปิดและสร้างเอกสารหลายรายการในแท็บใหม่ของหน้าต่างเดียวกันแทนที่จะเป็นในหน้าต่างใหม่
  • เพิ่มผลผลิตของคุณ 50% และลดการคลิกเมาส์หลายร้อยครั้งให้คุณทุกวัน!
ด้านล่าง officetab
จัดเรียงความคิดเห็นโดย
ความคิดเห็น (112)
ยังไม่มีการให้คะแนน เป็นคนแรกที่ให้คะแนน!
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
มันเจ๋งจริงๆ. และพบว่าง่ายต่อการเปลี่ยนคำว่า " ดอลลาร์ และส่งเป็นรูปีหรือสกุลเงินอื่น ๆ ที่เราต้องการโดยคัดลอกวาง cod ไปที่หน้าคำศัพท์ใหม่อื่น ๆ และแทนที่ Same
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันไม่ได้รับสูตรนี้ในชีตของฉัน ช่วยดูให้ละเอียดหน่อยได้ไหม
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ขอบคุณสำหรับข้อมูลอันมีค่าของคุณ ฉันต้องพูดถึงว่ามันคือ Dirham ไม่ใช่ดอลลาร์ ฉันจะทำให้มันเป็นได้อย่างไร ขอบคุณล่วงหน้า
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
โปรดเปลี่ยนคำทั้งหมด ~dollar/dollars" และ ~cent/cents" ในรหัสเป็นชื่อสกุลเงินของคุณ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันลองสิ่งนี้และใช้งานได้สำหรับฉัน ... ไปที่โมดูล ctrl F เพื่อค้นหา >>> จากนั้นใน find ใส่ Dollar แล้วไปที่แทนที่ (ในกล่องป๊อปอัปเดียวกัน) และใส่ Dirham มันจะทำงาน
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ปัญหาในการปัดเศษด้วยตัวเลข ตัวอย่างอยู่ในข้อมูลทั่วไปของฉันคือ 50.576 แต่เมื่อฉันปัดเศษและกลายเป็น 50.58 Words จะไม่เปลี่ยน/แปลงตามค่าใหม่
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
มันเป็นรหัสที่ทำงานได้ดี ขอบคุณมาก.
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เป็นสูตรที่ดีมาก แต่ฉันต้องการคำในรูปแบบอินเดีย
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
plx ทำให้ฉันชัดเจนว่าฉันจะเห็นมันในรูปแบบสกุลเงินของประเทศของฉันได้อย่างไร เช่น รูปีแทนดอลลาร์ และ Paisa แทนที่เซ็นต์
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เรียนท่านเจ้าคุณ มันเป็นสูตรที่ดีมาก แต่ฉันต้องการคำในรูปแบบอินเดีย โปรดแนะนำ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เป็นไปได้ไหมที่จะรับข้อมูลเป็น 100 หลังทศนิยมเช่น .100 คำตอบตะโกนเป็น 100 แทนที่จะเป็นสิบ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ขอบคุณสำหรับสูตร แต่เป็นไปได้ไหมที่จะได้รับคำว่า "ดอลลาร์/รูปี" เป็นคำนำหน้าเช่น รูปีหนึ่งพัน .... และ Paisas สามสิบเท่านั้น จะขอบคุณคำตอบของคุณจริงๆ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันจะเปลี่ยนจำนวนเงินในคำภาษาอังกฤษในสกุลเงินอินเดียได้อย่างไร
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
คัดลอกภาษาโค้ดด้านบนในแผ่นคำ แทนที่คำว่า "ดอลลาร์" ด้วย "รูปี" จากนั้นแทนที่คำว่า "เซ็นต์" ด้วย "ไพซ่า" กลับไปที่ไฟล์ excel กด alt+F11 แทรก >>> โมดูล >> วางไฟล์คำทั้งหมดจนถึง "end function" do .....=SpellNumberToEnglish(cellref) & you are good to go
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดีครับ ผมพยายามที่จะบันทึกมาโครตามที่คุณกล่าวไว้ข้างต้น และมันทำงานได้ดี แต่ถ้าฉันปิด excel แล้วเปิดแผ่นงานใหม่ มันจะไม่ทำงาน กรุณาช่วย
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
สวัสดี คุณสามารถติดตั้ง SPEL CURR เพิ่มคุณสามารถแปลง :) :) :lol:
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
เยอะมาก คุณช่วยบอกฉันที ฉันจะรับรูปแบบอินเดีย (รูปี) ได้อย่างไร
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ไม่ทำงาน ป๊อปอัปบอกว่าคลาสไม่ได้ลงทะเบียน ไม่มีตัวเลือกให้เลือกภาษา รหัสข้อผิดพลาด
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
wow ยอดเยี่ยมสำหรับสิ่งที่ฉันกำลังมองหามาหนึ่งสัปดาห์ มันใช้งานได้ดี ขอบคุณมาก
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
มันมีประโยชน์จริงๆ ขอบคุณมากจริงๆ :-)
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
THNX ATONE สำหรับเคล็ดลับดังกล่าว
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันได้ทำการวิจัยและไม่สามารถแปลงเป็นระบบสกุลเงินของปากีสถานได้ เนื่องจากคนเราใช้รูปแบบนี้ 1,00,00,00,00,000.00 แต่ excel ใช้รูปแบบนี้ 1,000,000,000,000 และรหัสอยู่ในสูตรล้านล้าน ฉันพยายามเปลี่ยนการขาดแคลน karor อาหรับ และ kharab แทนที่จะเป็นล้าน พันล้าน และล้านล้าน แต่จะเปลี่ยนเพียงคำพูดและระบบจะยังคงเหมือนเดิม เหมือนเปลี่ยนแล้วจะขึ้นแบบนี้ 100,000,000 มันควรจะเป็นร้อยล้าน แต่มันจะแสดงร้อยแสน ถ้าใครสามารถช่วยฉันได้ฉันจะขอบคุณคุณ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ฉันต้องการแปลงน้ำหนักเมตริกจากตัวเลขเป็นคำ เช่น. 1. 10.50 เมตริกตัน (MT) ควรเขียนว่า "10 ตันและ 500 กก." 2 12.345 MT = สิบสองตันและสามร้อยสี่สิบห้ากิโลกรัม ต้องการทศนิยม 3 ตำแหน่งอย่างน้อย และ 4 จะดีกว่า สูงสุด 9999.9999 คือสิ่งที่ฉันต้องการ ใครช่วยได้บ้าง
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
กรุณาถ้าคุณพบวิธี... โปรดส่งอีเมลฉัน islamrafat@gmail.com ขอบคุณ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
หากคุณพบโปรดส่งอีเมลถึงฉัน islamrafat@gmail.com
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
มหัศจรรย์. ขอบคุณ ขยายออฟฟิศ
ความคิดเห็นนี้ถูกย่อให้เล็กสุดโดยผู้ดำเนินรายการบนเว็บไซต์
ขอบคุณสำหรับความช่วยเหลือนี้ มันใช้งานได้ :-)
มีความคิดเห็นยังไม่มีการโพสต์ที่นี่
โหลดเพิ่มเติม
แสดงความคิดเห็นของคุณ
โพสต์ในฐานะแขก
×
ให้คะแนนโพสต์นี้:
0   ตัวอักษร
สถานที่แนะนำ