如何在Excel中将文本字符串转换为适当的大小写?

网友投稿 165 2023-12-18

如何在Excel中将文本字符串转换为适当的大小写?

 如何在Excel中将文本字符串转换为适当的大小写?

在Excel中,您可以应用Proper函数轻松地将文本字符串转换为大写形式,但是,有时,在将文本字符串转换为大写形式时,您需要排除一些特定的单词,如下图所示。 本文,我将讨论在Excel中解决此工作的一些快速技巧。

通过使用公式将文本字符串转换为适当的大小写例外

通过使用VBA代码将文本字符串转换为带例外的适当大小写

通过使用公式将文本字符串转换为适当的大小写例外
惊人的! 在 Excel 中使用高效的选项卡,如 Chrome、Firefox 和 Safari! 每天节省50%的时间,并减少数千次鼠标单击!

可能以下公式可以帮助您快速处理此任务,请这样做:

输入以下公式:

= UPPER(LEFT(A2))&MID(TRIM(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(“”&PROPER(A2)&“ “,”是“),”美国“,”美国“)),2,LEN(A2)) 放入要获取结果的单元格中,然后拖动填充手柄以填充此公式,并且文本字符串已转换为正确的大小写但特定的异常,请参见屏幕截图:

备注:在以上公式中, A2 是您要转换的单元格, “ Of”,“ A”,“ Is”,“ Usa” 是转换后的正常大小写单词, “ of”,“ a”,“ is”,“ USA” 是您要从适当情况中排除的单词。 您可以根据需要更改它们,或使用SUBSTITUTE功能添加其他单词。

通过使用VBA代码将文本字符串转换为带例外的适当大小写

如果上面的公式有些难以理解并且无法满足您的需要,在这里,您还可以应用VBA代码来完成此任务。 请一一进行以下步骤。

1。 按住 ALT + F11 键打开 Microsoft Visual Basic应用程序 窗口。

2。 点击 插页 > 模块,然后将以下代码粘贴到 模块窗口.

VBA代码:将文本字符串转换为适当的大小写,但以下情况除外:

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
Copy

3。 然后按 F5 键以运行此代码,并弹出一个提示框,提醒您选择要转换的原始单元格,请参见屏幕截图:

4。 然后点击 OK,在弹出的框中选择要在其中输出结果的单元格,请参见屏幕截图:

5。 继续点击 OK,然后在弹出对话框中,选择要排除的文本,请参见屏幕截图:

6。 然后点击 OK 退出对话框,并且所有文本字符串均已转换为适当的大小写,但排除了指定的单词,请参见屏幕截图:

最佳办公生产力工具

将小时转化为分钟 Kutools for Excel!

准备好增强您的 Excel 任务了吗? 利用的力量 Kutools for Excel - 您终极的节省时间的工具。 简化复杂的任务并像专业人士一样浏览数据。 以闪电般的速度体验 Excel!

为什么需要 Kutools for Excel

🛠️  超过 300 项强大功能: Kutools 包含 300 多项高级功能,可简化您在 1500 多种场景中的工作。

📈  卓越的数据处理能力:合并单元格、删除重复项并执行高级数据转换 - 所有这些都不费吹灰之力!

⏱️  高效的批量操作:当你可以聪明地工作时,为什么还要付出额外的努力呢? 轻松批量导入、导出、组合和调整数据。

📊  可定制的图表和报告:访问各种附加图表并生成富有洞察力的报告。

🗄️  强大的导航窗格:通过强大的列管理器、工作表管理器和自定义收藏夹获得优势。

📝  七种类型的下拉列表:通过各种功能和类型的下拉列表使数据输入变得轻而易举。

🎓  用户友好:对于初学者来说轻而易举,对于专家来说是一个强大的工具。

立即下载,与 Excel 一起穿越时空!

阅读更多 免费下载... 采购... 
Office Tab 为 Office 带来选项卡式界面,让您的工作更轻松
在Word,Excel,PowerPoint中启用选项卡式编辑和阅读,发布者,Access,Visio和Project。 在同一窗口的新选项卡中而不是在新窗口中打开并创建多个文档。 每天将您的工作效率提高50%,并减少数百次鼠标单击!
阅读更多 免费下载... 采购... 

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何将文本框中的文本转换为Excel中的单元格内容?
下一篇:如何在Excel中将文本字符串转换为公式?
相关文章