- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将 .dat 文件读入数据帧时遇到问题。我认为问题出在分隔符上。我在下面附上了文件中数据的屏幕截图。我最好的猜测是它是在列之间用制表符分隔,然后在行之间用换行符分隔。我尝试使用以下命令读取数据:
df = CSV.File("FORCECHAIN00046.dat"; header=false) |> DataFrame!
df = CSV.File("FORCECHAIN00046.dat"; header=false, delim = ' ') |> DataFrame!
无论哪种方式,我的结果都只是一个只有一列的 DataFrame,其中包括将每一列连接成一个字符串的所有数据。我什至尝试使用以下代码指定类型:
df = CSV.File("FORCECHAIN00046.dat"; types=[Float64,Float64,Float64,Float64,
Float64,Float64,Float64,Float64,Float64,Float64,Float64,Float64]) |> DataFrame!
我收到以下错误:
┌ Warning: 2; something went wrong trying to determine row positions for multithreading; it'd be very helpful if you could open an issue at https://github.com/JuliaData/CS
V.jl/issues so package authors can investigate
我可以通过将其上传到 google 表格然后下载 csv 来解决这个问题,但我想找到一种方法来使原始 .dat 文件正常工作。
最佳答案
这里的部分问题是 .dat
不是一种正确的文件格式——它只是一种似乎以某种人类可读的格式写出的东西,数字列由可变数字分隔空格,以便当您在编辑器中查看时,数字会对齐。 Google Sheets 内置了很多巧妙的技巧,可以为各种定义不明确的数据文件“做你想做的事”,所以我对它能够解析这些文件并不感到惊讶。另一方面,CSV 包支持使用单个字符作为分隔符甚至多字符字符串,但不支持像这样的可变数量的空格。
可能的解决方案:
这可能是最简单的方法,这里有一些 Julia 代码(未经测试,因为您没有提供测试数据)将打开您的文件并将其转换为更合理的格式:
function dat2csv(dat_path::AbstractString, csv_path::AbstractString)
open(csv_path, write=true) do io
for line in eachline(dat_path)
join(io, split(line), ',')
println(io)
end
end
return csv_path
end
function dat2csv(dat_path::AbstractString)
base, ext = splitext(dat_path)
ext == ".dat" ||
throw(ArgumentError("file name doesn't end with `.dat`"))
return dat2csv(dat_path, "$base.csv")
end
您可以将此函数称为 dat2csv("FORCECHAIN00046.dat")
,它会创建文件 FORCECHAIN00046.csv
,这将是一个使用逗号的正确 CSV 文件作为分隔符。如果文件中包含任何带逗号的值,那将无法正常工作,但看起来它们只是数字,在这种情况下应该没问题。因此,您可以使用此函数将文件转换为正确的 CSV,然后使用 CSV 包加载该文件。
代码的一点解释:
dat2csv
方法打开 csv_path
进行写入,然后调用 dat_path
上的 eachline
读取一个一次形成一行eachline
从每一行中去除任何尾随的换行符,因此每一行 line
都是由空格分隔的一堆数字,带有一些前导和/或尾随空格split(line)
执行 line
的默认拆分,即在空白处拆分它,删除任何空值——这只留下非空白条目作为字符串在数组join(io, split(line), ',')
将数组中的字符串连接在一起,由 ,
字符分隔并将其写入 io
为 csv_path
println(io)
在那之后写一个换行符——否则一切都将结束在一个很长的行上dat2csv
方法调用 splitext
将文件名拆分为基本名称和扩展名,检查扩展名是否为预期的 .dat
并调用双参数版本,将 .dat
替换为 .csv
关于csv - 在 Julia 中读取 .dat 文件,可变分隔符间距的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61665998/
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
我对 Angular 还很陌生。我有一个由一些数据填充的列表项: {{content.Company}} {{content.Town}}, {{content.P
我正在尝试从 SwiftUI 中的 List 中删除“行”分隔符(在 SwiftUI 中称为分隔符)。 我浏览了 List 文档,但我没能找到它的修饰符。 如有任何帮助,我们将不胜感激。 最佳答案 i
我有一个带有 4 个按钮的网格...1 行 4 列。我正在寻找一种方法将左侧的两个按钮与右侧的两个按钮进行视觉分组。我一直在寻找一种使用分隔符执行此操作的方法,但它似乎与 Grid 一起玩得不好,更喜
我对 R 语言相当陌生。所以我有这个包含以下内容的向量: > head(sampleVector) [1] "| txt01 | 100 | 200 | 123.456
我正在尝试连接两列中的值,当我使用 =CONCAT(A2,",",B2) 时,它将连接两列并获得正确的结果 (P0810,P1)。但我正在寻找的是这样的东西(“P0810”,“P1”)。我尝试了 =C
我在这里创建了一个简单的演示。在 amount 字段编辑时,我想显示 , 分隔符?目前,它仅在不处于编辑模式时显示 ,。知道如何实现这一目标吗? DEMO IN DOJO var data = [{
这里是java菜鸟... 这让我抓狂,因为我知道这很简单,但我已经为此工作了 30 分钟...... 这是来自代码战斗: 对于参数 = ["Code", "Fight", "On", "!"] 且分隔
基于这个pywin32基础script如何向托盘菜单 menu_options 添加分隔符? 我还可以让菜单在左键单击时弹出,而不仅仅是右键单击吗? 最佳答案 将 notify 函数(从 URL 中的
我正在使用这段代码: StringTokenizer tokenizer=new StringTokenizer(line, "::"); 拆分以下字符串: hi my name is visghal
- Dropbox login fix - Updated iris viewer * other aspects are to be improved + fix crash on viewing
我试图在每个菜单组之间显示一个分隔线。我已经尝试过为每个组提供一个唯一的 ID,但这没有用。我找到了一些其他解决方案,但它们看起来有点奇怪,比如创建高度为 1dp 的 LinearLayout。 这是
我想为 CONCAT_WS() 选择一个与字段值不冲突的分隔符例如,如果我选择“,”,则字段值可能包含带有“,”的字符串我想选择一个与字段值不冲突的分隔符:( 最佳答案 来自here : CONCAT
我想知道 Sphinx 引擎是否可以使用任何定界符(如普通 MySQL 中的逗号和句点)。我的问题来自于一种冲动,根本不使用它们,而是逃避它们,或者至少在使用 FULLTEXT 搜索执行 MATCH
我正在尝试使用 svg 或纯 css3 制作 header 分隔符,如下所示: preview from design 在 header 中我有标准的 bootstrap 4 轮播
我在使用 CSS 分隔符时遇到了一些难题。看看:http://jsfiddle.net/fVxC6/1/ .div-line { border-bottom: 1px solid #f0f0f
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 7 年前。 编辑问题以包含 desired behavior, a specific probl
嘿,我正在尝试使用 getline 读取以下行 (15,0,1,#) (2,11,2,.) (3,20,0,S) 我希望能够将整数提取为 int,将字符提取为 char,但我不知道如何只提取它们。 最
我有 2 列,每边 float 一列,我想使用 1px 宽度的线分隔符,从最长列的顶部到底部。 我宁愿远离 TABLE 布局,而且我不知道哪一个将是最长的列,或者它会有多长。 我怎么能只用 css 做
我是一名优秀的程序员,十分优秀!