提问人: 提问时间:10/3/2008 最后编辑:JimmyPena 更新时间:2/21/2023 访问量:627377
阻止 Excel 自动将某些文本值转换为日期
Stop Excel from automatically converting certain text values to dates
问:
有没有人碰巧知道我是否可以将某个字段的令牌添加到我的 csv 中,以便 Excel 不会尝试将其转换为日期?
我正在尝试从我的应用程序编写一个 .csv 文件,其中一个值恰好看起来像一个日期,Excel 会自动将其从文本转换为日期。我尝试将我所有的文本字段(包括看起来像日期的文本字段)放在双引号内,但这没有效果。
答:
如果在字段的开头放置一个倒置的逗号,它将被解释为文本。
示例:变为25/12/2008
'25/12/2008
您还可以在导入时选择字段类型。
评论
我发现在双引号前加上“=”将完成您想要的。它强制数据为文本。
例如。=“2008-10-03”,=“更多文字”
编辑(根据其他帖子):由于 Jeffiekins 指出的 Excel 2007 错误,应该使用 Andrew 提出的解决方案:"=""2008-10-03"""
评论
="xxx"
(假设 Excel 2003...)
使用“文本到列向导”时,在步骤 3 中,您可以指定每列的数据类型。单击预览中的列,然后将行为异常的列从“常规”更改为“文本”。
评论
警告:Excel '07(至少)有一个(其他)错误:如果字段的内容中有一个逗号,它不会正确解析 =“field, contents”,而是将逗号后面的所有内容放入以下字段中,而不管引号如何。
我发现唯一有效的解决方法是在字段内容包含逗号时消除 =。
这可能意味着有些字段不可能在Excel中完全“正确”地表示,但到目前为止,我相信没有人会感到惊讶。
评论
field, content
"
"=""field, co""ntent"""
""""
1"2
"1""2"
"=""1""""2"""
根据 Jarod 的解决方案和 Jeffiekins 提出的问题,您可以修改
"May 16, 2011"
自
"=""May 16, 2011"""
评论
"
"806676","None","41","=""05-16-2011""","100.00","False"
这是我们在生成csv文件时使用的简单方法,它确实会稍微改变值,因此它并不适合所有应用程序:
在 csv 中的所有值前面添加一个空格
excel 将从“1”、“2.3” 和 “-2.9e4” 等数字中剥离此空间,但将保留在“01/10/1993”等日期和“TRUE”等布尔值上,从而阻止它们转换为 excel 的内部数据类型。
它还可以阻止在读入时使用双引号,因此即使像“3.1415”这样的文本,也可以使 csv 中的文本保持不变,方法是用双引号将其括起来,并在整个字符串前面加上一个空格,即(使用单引号显示您将键入的内容)' “3.1415”'。然后在 excel 中,您始终拥有原始字符串,只是它被双引号括起来并在前面加上一个空格,因此您需要在任何公式等中考虑这些字符串。
评论
"\xA0"
我遇到了类似的问题,这是无需编辑csv文件内容即可帮助我的解决方法:
如果您可以灵活地将文件命名为“.csv”以外的其他名称,则可以使用“.txt”扩展名命名它,例如“Myfile.txt”或“Myfile.csv.txt”。然后,当您在Excel中打开它时(不是通过拖放,而是使用文件>打开或最近使用的文件列表),Excel将为您提供“文本导入向导”。
在向导的第一页中,选择“分隔”作为文件类型。
在向导的第二页中,选择“,”作为分隔符,如果值用引号括起来,则还要选择文本限定符
在第三页中,单独选择每一列,并为每列分配类型“文本”而不是“常规”,以防止 Excel 弄乱您的数据。
希望这对您或有类似问题的人有所帮助!
评论
我知道这是一个老问题,但问题不会很快消失。CSV 文件很容易从大多数编程语言生成,相当小,使用纯文本编辑器在紧缩中人类可读,并且无处不在。
问题不仅在于文本字段中的日期,而且任何数字也会从文本转换为数字。有几个例子是有问题的:
- 邮政编码
- 电话号码
- 政府身份证号码
有时可以以一个或多个零 (0) 开头,当转换为数字时会被丢弃。或者,该值包含可能与数学运算符混淆的字符(如日期:/、-)。
我能想到的两种情况是,如前所述,“前缀 =”解决方案可能并不理想,它们是
- 文件可能被导入到 MS Excel 以外的程序中(我想到了 MS Word 的邮件合并功能),
- 人类的可读性可能很重要。
我的技巧可以解决这个问题
如果在值中预加/附加非数字和/或非日期字符,则该值将被识别为文本而不是转换。非打印字符会很好,因为它不会改变显示的值。但是,普通的旧空格字符(\s,ASCII 32)不适用于此,因为它被 Excel 砍掉,然后该值仍被转换。但是还有其他各种打印和非打印空格字符可以很好地工作。然而,最简单的方法是附加(添加)简单的制表符(\t,ASCII 9)。
这种方法的优点:
- 可通过键盘或易于记忆的 ASCII 代码 (9) 提供,
- 它不打扰进口,
- 通常不会打扰邮件合并结果(取决于模板布局 - 但通常它只是在行尾添加一个宽空间)。(但是,如果这是一个问题,请查看其他字符,例如零宽度空格(ZWSP,Unicode U+200B)
- 在记事本(等)中查看CSV时不是很大的障碍,
- 并且可以通过在Excel(或记事本等)中查找/替换来删除。
- 您无需导入 CSV,只需双击即可在 Excel 中打开 CSV。
如果出于某种原因不想使用该选项卡,请在 Unicode 表中查找其他合适的内容。
另一种选择
可能是生成 XML 文件,较新的 MS Excel 版本也接受某种格式导入,并且允许更多类似于 .XLS 格式的选项,但我没有这方面的经验。
所以有多种选择。根据您的要求/应用,一个可能比另一个更好。
加法
需要说的是,较新版本(2013+)的MS Excel不再以电子表格格式打开CSV - 工作流程中的又一个减速带使Excel的用处降低......至少,存在绕过它的说明。例如,请参阅此Stackoverflow:如何在Excel 2013中正确显示.csv文件?
评论
\t
;
column_name
'
本周我遇到了这个约定,这似乎是一个很好的方法,但我在任何地方都找不到它被引用。有人熟悉吗?你能引用它的来源吗?我没有找几个小时,但希望有人能认识到这种方法。
示例 1:=(“012345678905”) 显示为012345678905
示例 2:=(“1954-12-12”) 显示为 1954-12-12,而不是 12/12/1954。
这是我知道如何在不弄乱文件本身的情况下完成此操作的唯一方法。像往常一样,我通过在桌子上敲打几个小时来学习这一点。
将 .csv 文件扩展名更改为 .txt;这将阻止 Excel 在打开文件时自动转换文件。我的做法是这样的:将 Excel 打开到一个空白工作表,关闭空白工作表,然后 File => Open 并选择扩展名为 .txt 的文件。这会强制 Excel 打开“文本导入向导”,它会询问您有关您希望它如何解释文件的问题。首先,选择分隔符(逗号、制表符等),然后(这是重要的部分)选择一组列的列并选择格式。如果您确切地想要文件中的内容,请选择“文本”,Excel 将显示分隔符之间的内容。
评论
awk
中的数据 - 避免重新格式化类似日期的值,问题出在 Excel 而不是 ,尽管有问题标题。awk
在 Excel 2010 中,打开一个新工作表。 在“数据”功能区上,单击“从文本中获取外部数据”。 选择您的CSV文件,然后单击“打开”。 点击“下一步”。 取消选中“Tab”,在“逗号”旁边打勾,然后单击“下一步”。 单击第一列上的任意位置。 在按住 shift 键的同时,拖动滑块,直到您可以单击最后一列,然后松开 shift 键。 单击“文本”单选按钮,然后单击“完成”
所有列都将作为文本导入,就像它们在 CSV 文件中一样。
评论
嗨,我有同样的问题,
我编写此 vbscipt 以创建另一个 CSV 文件。新的 CSV 文件在每个字段的字体中都有一个空格,因此 excel 会将其理解为文本。
因此,使用以下代码(例如 Modify_CSV.vbs)创建一个 .vbs 文件,保存并关闭它。将您的原始文件拖放到您的 vbscript 文件中。它将在同一位置创建一个带有“SPACE_ADDED”文件名的新文件。
Set objArgs = WScript.Arguments
Set objFso = createobject("scripting.filesystemobject")
dim objTextFile
dim arrStr ' an array to hold the text content
dim sLine ' holding text to write to new file
'Looping through all dropped file
For t = 0 to objArgs.Count - 1
' Input Path
inPath = objFso.GetFile(wscript.arguments.item(t))
' OutPut Path
outPath = replace(inPath, objFso.GetFileName(inPath), left(objFso.GetFileName(inPath), InStrRev(objFso.GetFileName(inPath),".") - 1) & "_SPACE_ADDED.csv")
' Read the file
set objTextFile = objFso.OpenTextFile(inPath)
'Now Creating the file can overwrite exiting file
set aNewFile = objFso.CreateTextFile(outPath, True)
aNewFile.Close
'Open the file to appending data
set aNewFile = objFso.OpenTextFile(outPath, 8) '2=Open for writing 8 for appending
' Reading data and writing it to new file
Do while NOT objTextFile.AtEndOfStream
arrStr = split(objTextFile.ReadLine,",")
sLine = "" 'Clear previous data
For i=lbound(arrStr) to ubound(arrStr)
sLine = sLine + " " + arrStr(i) + ","
Next
'Writing data to new file
aNewFile.WriteLine left(sLine, len(sLine)-1) 'Get rid of that extra comma from the loop
Loop
'Closing new file
aNewFile.Close
Next ' This is for next file
set aNewFile=nothing
set objFso = nothing
set objArgs = nothing
在 C# 中创建要写入我的 CSV 文件的字符串时,我必须以这种方式格式化它:
"=\"" + myVariable + "\""
评论
好的,在Excel 2003到2007中找到了一种简单的方法来执行此操作。打开一个空白的 xls 工作簿。然后转到“数据”菜单,导入外部数据。选择您的 csv 文件。浏览向导,然后在“列数据格式”中选择需要强制为“文本”的任何列。这会将整个列导入为文本格式,防止 Excel 尝试将任何特定单元格视为日期。
它不是 Excel。Windows 确实可以识别公式、数据作为日期并自动更正。您必须更改 Windows 设置。
“控制面板”(->“切换到经典视图”)->“区域和语言 选项“ -> 选项卡 ”区域选项“ -> ”自定义...“ ->选项卡 ”数字“ -> 和 然后根据需要更改符号。
http://www.pcreview.co.uk/forums/enable-disable-auto-convert-number-date-t3791902.html
它将在您的计算机上运行,如果这些设置未更改,例如在客户的计算机上,他们将看到日期而不是数据。
评论
在不修改 csv 文件的情况下,您可以:
- 将excel的“设置单元格格式”选项更改为“文本”
- 然后使用“文本导入向导”定义csv单元格。
- 导入后,删除该数据
- 然后粘贴为纯文本
Excel 将正确地格式化您的 CSV 单元格并将其分隔为文本格式,忽略自动日期格式。
有点愚蠢的解决方法,但它胜过在导入之前修改 csv 数据。安迪·贝尔德(Andy Baird)和理查德(Richard)在某种程度上回避了这种方法,但错过了几个重要的步骤。
我知道这是一个旧线程。对于像我这样的人,他们仍然有这个问题,通过 PowerShell COM 对象使用 Office 2013 可以使用 opentext 方法。问题在于这种方法有许多参数,有时是相互排斥的。要解决此问题,您可以使用本文中介绍的方法。
一个例子是invoke-namedparameter
$ex = New-Object -com "Excel.Application"
$ex.visible = $true
$csv = "path\to\your\csv.csv"
Invoke-NamedParameter ($ex.workbooks) "opentext" @{"filename"=$csv; "Semicolon"= $true}
不幸的是,我刚刚发现,当单元格包含换行符时,这种方法以某种方式破坏了 CSV 解析。CSV支持这一点,但Microsoft的实现似乎存在错误。 此外,它不知何故没有检测到特定于德语的字符。赋予它正确的文化并没有改变这种行为。所有文件(CSV 和脚本)都以 utf8 编码保存。 首先,我编写了以下代码来逐个单元格插入 CSV。
$ex = New-Object -com "Excel.Application"
$ex.visible = $true;
$csv = "path\to\your\csv.csv";
$ex.workbooks.add();
$ex.activeWorkbook.activeSheet.Cells.NumberFormat = "@";
$data = import-csv $csv -encoding utf8 -delimiter ";";
$row = 1;
$data | %{ $obj = $_; $col = 1; $_.psobject.properties.Name |%{if($row -eq1){$ex.ActiveWorkbook.activeSheet.Cells.item($row,$col).Value2= $_ };$ex.ActiveWorkbook.activeSheet.Cells.item($row+1,$col).Value2 =$obj.$_; $col++ }; $row++;}
但这非常慢,这就是我寻找替代方案的原因。显然,Excel允许您使用矩阵设置一系列单元格的值。因此,我使用这篇博客中的算法来转换多阵列中的 CSV。
function csvToExcel($csv,$delimiter){
$a = New-Object -com "Excel.Application"
$a.visible = $true
$a.workbooks.add()
$a.activeWorkbook.activeSheet.Cells.NumberFormat = "@"
$data = import-csv -delimiter $delimiter $csv;
$array = ($data |ConvertTo-MultiArray).Value
$starta = [int][char]'a' - 1
if ($array.GetLength(1) -gt 26) {
$col = [char]([int][math]::Floor($array.GetLength(1)/26) + $starta) + [char](($array.GetLength(1)%26) + $Starta)
} else {
$col = [char]($array.GetLength(1) + $starta)
}
$range = $a.activeWorkbook.activeSheet.Range("a1:"+$col+""+$array.GetLength(0))
$range.value2 = $array;
$range.Columns.AutoFit();
$range.Rows.AutoFit();
$range.Cells.HorizontalAlignment = -4131
$range.Cells.VerticalAlignment = -4160
}
function ConvertTo-MultiArray {
param(
[Parameter(Mandatory=$true, Position=1, ValueFromPipeline=$true)]
[PSObject[]]$InputObject
)
BEGIN {
$objects = @()
[ref]$array = [ref]$null
}
Process {
$objects += $InputObject
}
END {
$properties = $objects[0].psobject.properties |%{$_.name}
$array.Value = New-Object 'object[,]' ($objects.Count+1),$properties.count
# i = row and j = column
$j = 0
$properties |%{
$array.Value[0,$j] = $_.tostring()
$j++
}
$i = 1
$objects |% {
$item = $_
$j = 0
$properties | % {
if ($item.($_) -eq $null) {
$array.value[$i,$j] = ""
}
else {
$array.value[$i,$j] = $item.($_).tostring()
}
$j++
}
$i++
}
$array
}
}
csvToExcel "storage_stats.csv" ";"
您可以按原样使用上述代码;它应该将任何CSV转换为Excel。只需更改 CSV 的路径和底部的分隔符即可。
评论
此问题仍然存在于 Mac Office 2011 和 Office 2013 中,我无法阻止它发生。这似乎是一件基本的事情。
就我而言,我在CSV中将“1 - 2”和“7 - 12”等值正确括在倒逗号中,这会自动转换为excel中的日期,如果您随后尝试将其转换为纯文本,您将获得日期的数字表示,例如43768。此外,它还将条形码和 EAN 编号中的大量数字重新格式化为 123E+ 数字,这些数字无法转换回来。
我发现 Google Drive 的 Google 表格不会将数字转换为日期。条形码每 3 个字符中确实有逗号,但这些逗号很容易删除。它可以很好地处理 CSV,尤其是在处理 MAC / Windows CSV 时。
也许有一天会救人。
最简单的解决方案 我今天才想通了。
- 在 Word 中打开
- 将所有连字符替换为短划线
- 保存并关闭
- 在 Excel 中打开
完成编辑后,您可以随时再次在 Word 中重新打开它,以再次用连字符替换短划线。
(EXCEL 2007 及更高版本)
如何在不编辑源文件的情况下强制 excel 不“检测”日期格式
也:
- 将文件重命名为 .txt
- 如果无法执行此操作,请不要直接在 excel 中打开 CSV 文件,而是创建一个新工作簿,然后转到
并选择您的 CSV。Data > Get external data > From Text
无论哪种方式,您都会看到导入选项,只需选择包含日期的每一列,然后告诉 excel 格式为“文本”而不是“常规”。
在Microsoft Office 2016版本中仍然是一个问题,对于我们这些使用MARC1,MARCH1,SEPT1等基因名称的人来说,这是相当令人不安的。 在 R 中生成“.csv”文件后,我发现的解决方案是最实用的,然后将打开/与 Excel 用户共享:
- 以文本形式打开 CSV 文件(记事本)
- 复制它 (ctrl+a, ctrl+c)。
- 将其粘贴到新的 Excel 工作表中 - 它将全部粘贴为一列长文本字符串。
- 选择/选择此列。
- 转到数据-“文本到列...”,在打开的窗口中选择“分隔”(下一步)。检查是否标记了“逗号”(标记它已显示数据与以下列的分隔)(下一步),在此窗口中,您可以选择所需的列并将其标记为文本(而不是常规)(完成)。
HTH
评论
对于同样的问题,我所做的是在每个 csv 值之前添加以下内容: "=""" 在 Excel 中打开文件之前,每个 CSV 值后都有一个双引号。以以下值为例:
012345,00198475
在 Excel 中打开之前,应将这些内容更改为:
"="""012345","="""00198475"
执行此操作后,每个单元格值都会在 Excel 中显示为公式,因此不会格式化为数字、日期等。例如,值 012345 显示为:
="012345"
评论
1234500198475E-8
012345
00198475
就我而言,使用 R 生成的 csv 文件中的“Sept8”被 Excel 2013 转换为“8-Sept”。通过使用 xlsx 包中的 write.xlsx2() 函数生成 xlsx 格式的输出文件,解决了该问题,该文件可以通过 Excel 加载而无需进行不必要的转换。因此,如果给你一个 csv 文件,你可以尝试将其加载到 R 中并使用 write.xlsx2() 函数将其转换为 xlsx。
评论
我这样做是为了不断转换为科学记数法的信用卡号:我最终将我的 .csv 导入 Google 表格。导入选项现在允许禁用数值的自动格式设置。我将任何敏感列设置为纯文本并下载为 xlsx。
这是一个糟糕的工作流程,但至少我的价值观保持了应有的状态。
评论
这里提供的解决方案都不是一个好的解决方案。它可能适用于个别情况,但前提是您控制了最终显示。以我为例:我的工作产生了他们出售给零售的产品清单。这是CSV格式,包含零件代码,其中一些以零开头,由制造商设置(不受我们的控制)。去掉前导零,你实际上可以匹配另一个产品。 零售客户希望以 CSV 格式显示列表,因为后端处理程序也超出了我们的控制范围,并且每个客户都不同,因此我们无法更改 CSV 文件的格式。没有前缀'=',也没有添加制表符。原始 CSV 文件中的数据是正确的;当客户在 Excel 中打开这些文件时,问题就开始了。而且许多客户并不真正精通计算机。他们几乎可以打开并保存电子邮件附件。 我们正在考虑以两种略有不同的格式提供数据:一种是 Excel 友好(使用上面建议的选项,通过添加一个 TAB,另一种作为“主”。但这可能是一厢情愿的想法,因为有些客户不明白我们为什么需要这样做。与此同时,我们继续解释为什么他们有时会在电子表格中看到“错误”的数据。 在 Microsoft 做出适当的更改之前,我认为没有适当的解决方案,只要人们无法控制最终用户如何使用文件。
评论
"\xA0"
使用 Google 云端硬盘(如果您使用的是 Mac,则为 Numbers)的解决方法:
- 在 Excel 中打开数据
- 将数据不正确的列的格式设置为文本(>单元格格式>数字>文本)
- 将 .csv 加载到 Google 云端硬盘中,然后使用 Google 表格打开它
- 复制有问题的列
- 将列作为文本粘贴到 Excel 中(编辑>粘贴特殊>文本)
或者,如果您使用的是 Mac 进行第 3 步,则可以在 Numbers 表格中打开数据。
评论
(EXCEL 2016及更高版本,其实我没有在旧版本中尝试过)
- 打开新的空白页
- 转到“数据”选项卡
- 单击“从文本/CSV”并选择您的 csv 文件
- 在预览中检查数据是否正确。
- 在将某些列转换为日期时,单击“编辑”,然后通过单击列标题中的日历来选择键入文本
- 点击“关闭并加载”
2018
唯一适合我的正确解决方案(并且也没有修改 CSV)。
Excel 2010:
- 创建新工作簿
- 从文本>>数据 选择您的 CSV 文件
- 在弹出窗口中,选择“分隔”单选按钮,然后单击“下一>”
- 分隔符复选框:仅勾选“逗号”并取消选中其他选项,然后单击“下一个>”
- 在“数据预览”中,滚动到最右侧,然后按住 shift 键并单击最后一列(这将选择所有列)。现在在“列数据格式”中选择单选按钮“文本”,然后单击“完成”。
Excel office365:(客户端版本)
- 创建新工作簿
- 从文本/CSV >>数据 选择您的 CSV 文件
- 数据类型检测>不检测
注意:Excel office365(网络版),当我写这篇文章时,您将无法这样做。
评论
如果有人仍在寻找答案,下面的行非常适合我
我输入了=(“my_value”)。
即 显示为 not as=("04SEP2009")
04SEP2009
09/04/2009
这同样适用于超过 15 位的整数。他们不再被修剪了。
如果可以更改文件源数据
如果您准备更改原始源 CSV 文件,另一种选择是更改数据中的“分隔符”,因此,如果您的数据是“4/11”(或 4-11),并且 Excel 将其转换为 4/11/2021(英国或 11-4-2021 美国),那么将“/”或“-”字符更改为其他字符将阻止不必要的 Excel 日期转换。选项可能包括:
- 波浪号 ('~')
- 加号 ('+')
- 强调 ('_')
- 双破折号 ('--')
- 短划线 (Alt 150)
- Em-dash (替代项 151)
- (其他一些角色!
注意:如果要在其他地方使用文件,则移动到 Unicode 或其他非 ASCII/ansi 字符可能会使问题复杂化。
因此,将“4-11”转换为带有波浪号的“4~11”将不被视为日期!
对于大型 CSV 文件,这没有额外的开销(即:额外的引号/空格/制表符/公式构造),并且仅在直接打开文件时起作用(即:双击 CSV 打开),并避免将列预先格式化为文本或将 CSV 文件“导入”为文本。
如有必要,记事本(或类似工具)中的搜索/替换可以很容易地与替代分隔符相互转换。
导入原始数据
在较新版本的 Excel 中,您可以导入数据(在其他答案中概述)。 在旧版本的 Excel 中,可以安装“Power Query”加载项。此工具还可以导入 CSV,而无需转换。选择:“Power Query”选项卡/“从文件”/“从文本-CSV”,然后选择“加载”以表形式打开。(您可以从“数据类型检测”选项中选择“不检测数据类型”)。
评论