Přejít k hlavnímu obsahu
 

 Jak převést textový řetězec na správný případ s výjimkami v aplikaci Excel?

Autor: Xiaoyang Naposledy změněno: 2024-08-12

V aplikaci Excel můžete použít funkci Správný k snadnému převodu textových řetězců na správná velikost písmen, ale někdy je třeba při převodu textových řetězců na správný případ vyloučit některá konkrétní slova, jak ukazuje následující snímek obrazovky. V tomto článku budu hovořit o několika rychlých tricích pro řešení této úlohy v aplikaci Excel.

převést textový řetězec na správná velká a malá písmena s výjimkami

Převeďte textové řetězce na velká a malá písmena s výjimkou pomocí vzorce

Převod textových řetězců na správné velikosti písmen s výjimkami pomocí kódu VBA


Převeďte textové řetězce na velká a malá písmena s výjimkou pomocí vzorce

Následující vzorec vám může pomoci rychle se s tímto úkolem vypořádat, postupujte takto:

Zadejte tento vzorec:

= UPPER (LEFT (A2)) & MID (TRIM (SUBSTITUTE (SUBSTITUTE (SUBSTITUTE (SUBSTITUTE ("" & PROPER (A2) & "", "Of", "of"), "A", "a"), "Is "," is ")," USA "," USA ")), 2, LEN (A2)) do buňky, kde chcete získat výsledek, a potom přetažením úchytu výplně vyplňte tento vzorec a textové řetězce byly převedeny na správný případ, ale konkrétní výjimky, viz screenshot:

převést textový řetězec na správná velká a malá písmena s výjimkami pomocí vzorce

Pozor: Ve výše uvedeném vzorci, A2 je buňka, kterou chcete převést, „Of“, „A“, „Is“, „Usa“ jsou normální správná velká a malá slova po převodu, „Of“, „a“, „is“, „USA“ jsou slova, která chcete vyloučit ze správného případu. Můžete je podle potřeby změnit nebo přidat další slova pomocí funkce SUBSTITUTE.



Převod textových řetězců na správné velikosti písmen s výjimkami pomocí kódu VBA

Pokud je výše uvedený vzorec poněkud obtížné pochopit a změnit podle vašich potřeb, zde můžete k dokončení tohoto úkolu použít také kód VBA. Postupně proveďte následující kroky.

1. Podržte ALT + F11 klávesy pro otevření Microsoft Visual Basic pro aplikace okno.

2, klikněte Vložit > Modula vložte následující kód do Okno modulu.

Kód VBA: převést textové řetězce na správná velikost písmen s výjimkami:

Sub CellsValueChange()
'Updateby Extendoffice
    Dim xSRg As Range
    Dim xDRg As Range
    Dim xPRg As Range
    Dim xSRgArea As Range
    Dim xRgVal As String
    Dim xAddress As String
    Dim I As Long
    Dim K As Long
    Dim KK As Long
    On Error Resume Next
    xAddress = Application.ActiveWindow.RangeSelection.Address
    Set xSRg = Application.InputBox("Original cells:", "KuTools For Excel", xAddress, , , , , 8)
    If xSRg Is Nothing Then Exit Sub
    Set xDRg = Application.InputBox("Output cells:", "KuTools For Excel", , , , , , 8)
    If xDRg Is Nothing Then Exit Sub
    Set xPRg = Application.InputBox("Cells to exclude:", "KuTools For Excel", , , , , , 8)
    If xPRg Is Nothing Then Exit Sub
    Set xDRg = xDRg(1)
    For I = 1 To xSRg.Areas.Count
        Set xSRgArea = xSRg.Areas.Item(I)
        For K = 1 To xSRgArea.Count
            xRgVal = xSRgArea(K).Value
            If Not IsNumeric(xRgVal) Then
                xRgVal = CorrectCase(xRgVal, xPRg)
                xDRg.Offset(KK).Value = xRgVal
            End If
            KK = KK + 1
        Next
    Next
End Sub
Function CorrectCase(ByVal xRgVal As String, ByVal xPRg As Range) As String
    Dim xArrWords As Variant
    Dim I As Integer
    Dim xPointer As Integer
    Dim xVal As String
    xPointer = 1
    xVal = xRgVal
    xArrWords = WordsOf(xRgVal)
    For I = 0 To UBound(xArrWords)
        xPointer = InStr(xPointer, " " & xVal, " " & xArrWords(I))
        Debug.Print xPointer
        Mid(xVal, xPointer) = CorrectCaseOneWord(CStr(xArrWords(I)), xPRg)
    Next I
    CorrectCase = xVal
End Function
Function WordsOf(xRgVal As String) As Variant
    Dim xDelimiters As Variant
    Dim xArrRtn As Variant
    xDelimiters = Array(",", ".", ";", ":", Chr(34), vbCr, vbLf)
    For Each xEachDelimiter In xDelimiters
        xRgVal = Application.WorksheetFunction.Substitute(xRgVal, xEachDelimiter, " ")
    Next xEachDelimiter
    xArrRtn = Split(Trim(xRgVal), " ")
    WordsOf = xArrRtn
End Function
Function CorrectCaseOneWord(xArrWord As String, xERg As Range) As String
    With xERg
        If IsError(Application.Match(xArrWord, .Cells, 0)) Then
            CorrectCaseOneWord = Application.Proper(xArrWord)
        Else
            CorrectCaseOneWord = Application.VLookup(xArrWord, .Cells, 1, 0)
        End If
    End With
End Function

3. Pak stiskněte tlačítko F5 klíč ke spuštění tohoto kódu a zobrazí se okno s výzvou, které vám připomene, abyste vybrali původní buňky, které chcete převést, viz screenshot:

vba kód pro výběr datového rozsahu

4. A pak klikněte na tlačítko OK, ve vyskakovacím poli vyberte buňky, do kterých chcete výsledky odeslat, viz screenshot:

vba kód do cílové buňky

5. Jděte na kliknutí OKa v rozbalovacím dialogovém okně vyberte texty, které chcete vyloučit, viz screenshot:

vba kód pro výběr vyloučeného textu

6. A pak klikněte na tlačítko OK ukončíte dialogy a všechny textové řetězce byly převedeny na správná velikost písmen, ale vyloučte zadaná slova, viz screenshot:

výsledek převodu textového řetězce na správná velká a malá písmena s výjimkami

Nejlepší nástroje pro produktivitu v kanceláři

🤖 Kutools AI asistent: Revoluční analýza dat založená na: Inteligentní provedení   |  Generovat kód  |  Vytvořte vlastní vzorce  |  Analyzujte data a generujte grafy  |  Vyvolejte funkce Kutools...
Populární funkce: Najít, zvýraznit nebo identifikovat duplikáty   |  Odstranit prázdné řádky   |  Kombinujte sloupce nebo buňky bez ztráty dat   |   Kolo bez vzorce ...
Super vyhledávání: Více kritérií VLookup    VLookup s více hodnotami  |   VLookup na více listech   |   Fuzzy vyhledávání ....
Pokročilý rozevírací seznam: Rychle vytvořte rozevírací seznam   |  Závislý rozbalovací seznam   |  Vícenásobný výběr rozevíracího seznamu ....
Správce sloupců: Přidejte konkrétní počet sloupců  |  Přesunout sloupce  |  Přepnout stav viditelnosti skrytých sloupců  |  Porovnejte rozsahy a sloupce ...
Doporučené funkce: Zaměření mřížky   |  Návrhové zobrazení   |   Velký Formula Bar    Správce sešitů a listů   |  Knihovna zdrojů (Automatický text)   |  Výběr data   |  Zkombinujte pracovní listy   |  Šifrovat/dešifrovat buňky    Odesílat e-maily podle seznamu   |  Super filtr   |   Speciální filtr (filtr tučné/kurzíva/přeškrtnuté...) ...
Top 15 sad nástrojů12 Text Tools (doplnit text, Odebrat znaky, ...)   |   50+ Graf Typ nemovitosti (Ganttův diagram, ...)   |   40+ Praktické Vzorce (Vypočítejte věk na základě narozenin, ...)   |   19 Vložení Tools (Vložte QR kód, Vložit obrázek z cesty, ...)   |   12 Konverze Tools (Čísla na slova, Přepočet měny, ...)   |   7 Sloučit a rozdělit Tools (Pokročilé kombinování řádků, Rozdělit buňky, ...)   |   ... a více

Rozšiřte své dovednosti Excel pomocí Kutools pro Excel a zažijte efektivitu jako nikdy předtím. Kutools for Excel nabízí více než 300 pokročilých funkcí pro zvýšení produktivity a úsporu času.  Kliknutím sem získáte funkci, kterou nejvíce potřebujete...


Office Tab přináší do Office rozhraní s kartami a usnadňuje vám práci

  • Povolte úpravy a čtení na kartách ve Wordu, Excelu, PowerPointu, Publisher, Access, Visio a Project.
  • Otevřete a vytvořte více dokumentů na nových kartách ve stejném okně, nikoli v nových oknech.
  • Zvyšuje vaši produktivitu o 50%a snižuje stovky kliknutí myší každý den!