gpt4 book ai didi

netlogo - 将包含文本和数字的 Excel .txt 文件读入 NetLogo

转载 作者:行者123 更新时间:2023-12-01 12:40:08 39 4
gpt4 key购买 nike

我在 Excel 中准备了一个包含文本和数字的文件,例如第 1 行将包含 MyAge 20 MyYear 1994。我将其保存为 .txt(文本制表符分隔)文件并尝试将其读入 Netlogo。当我在记事本中打开文件时,数字显示为数字,文本显示为“”。 Netlogo 不会读取文件说“期望一个常量”。如果我删除文本或手动用引号将文本括起来,那么它就可以正常工作。因此,如果我的行是:"MyAge"20 "MyYear"1994,它 owkrs ifne。

对于小数据集来说,手动添加 "' 到所有字符串将是乏味的,而对于大数据集,几乎不可能。

我怎样才能克服这个问题。我可以将其另存为其他格式吗?或者我应该更改我在下面使用的 netlogo 代码:

 let itemsAB read-from-string (word "[" file-read-line "]")

谢谢。

最佳答案

我不太了解 Excel,但如果无法在您需要的地方添加引号,无论是在电子表格中还是在导出时,我都会感到惊讶。

也就是说,您也可以在 NetLogo 中解决这个问题。

使用 read-from-string (word "["file-read-line "]") 可能非常有用,但它只有在数据格式正确时才有效。在您的情况下,您需要使用不同的方法。

您首先需要的是一个可以根据某个定界符拆分字符串的报告程序。您可以在 NetLogo String Extension 中找到一个, 但这是直接用 NetLogo 编写的:

to-report split [ string delim ]
report reduce [
ifelse-value (?2 = delim)
[ lput "" ?1 ]
[ lput word last ?1 ?2 but-last ?1 ]
] fput [""] n-values (length string) [ substring string ? (? + 1) ]
end

例如,调用 split "a-b-c""-" 会报告 ["a""b""c"]。但就您而言,如果我没记错的话,您的字段由制表符分隔。 NetLogo 中的制表符是 \t,所以它会像 split "a\tb\tc""\t" 那样。

现在您可以通过以下方式读取文件内容:

to read-content

let line1 "MyAge\t20\tMyYear\t1994" ; in real life, you'll use file-read-line
let items split line1 "\t"
show items ; will be: ["MyAge" "20" "MyYear" "1994"]

; If you know the types, you can read the items one by one.
; Only apply `read-from-string` to numbers:
let itemsAB1 (list
item 0 items
read-from-string item 1 items
item 2 items
read-from-string item 3 items
)
show itemsAB1 ; ["MyAge" 20 "MyYear" 1994]

; You could also "carefully" try to convert everything to numbers:
let itemsAB2 map try-to-read items
show itemsAB2 ; ["MyAge" 20 "MyYear" 1994]

end

to-report try-to-read [ string ]
let result string
carefully [ set result read-from-string string ] []
report result
end

我已经向您展示了两种不同的方式来阅读一行的内容。第一个是最直接的,只尝试转换(使用 read-from-string )您已经知道是数字的项目。

第二种方法使用carefully尝试使用 read-from-string 转换每个项目.对于那些成功的,它会报告转换后的项目。对于失败的,它会报告原始字符串。为了完整起见,我将其放在这里,但第一种方法不太可能导致无法预料的麻烦。

关于netlogo - 将包含文本和数字的 Excel .txt 文件读入 NetLogo,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25675239/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com