strconv.ParseInt 给出 0
strconv.ParseInt gives 0
我正在尝试解析这种形式的文件:
12
0,1,2,3,1,2,3,4,2,3,4,5
1,0,1,2,2,1,2,3,3,2,3,4
2,1,0,1,3,2,1,2,4,3,2,3
3,2,1,0,4,3,2,1,5,4,3,2
1,2,3,4,0,1,2,3,1,2,3,4
2,1,2,3,1,0,1,2,2,1,2,3
3,2,1,2,2,1,0,1,3,2,1,2
4,3,2,1,3,2,1,0,4,3,2,1
2,3,4,5,1,2,3,4,0,1,2,3
3,2,3,4,2,1,2,3,1,0,1,2
4,3,2,3,3,2,1,2,2,1,0,1
5,4,3,2,4,3,2,1,3,2,1,0
0,5,2,4,1,0,0,6,2,1,1,1
5,0,3,0,2,2,2,0,4,5,0,0
2,3,0,0,0,0,0,5,5,2,2,2
4,0,0,0,5,2,2,10,0,0,5,5
1,2,0,5,0,10,0,0,0,5,1,1
0,2,0,2,10,0,5,1,1,5,4,0
0,2,0,2,0,5,0,10,5,2,3,3
6,0,5,10,0,1,10,0,0,0,5,0
2,4,5,0,0,1,5,0,0,0,10,10
1,5,2,0,5,5,2,0,0,0,5,0
1,0,2,5,1,4,3,5,10,5,0,2
1,0,2,5,1,0,3,0,10,0,2,0
第一行给出了矩阵的大小:n x n
接下来的n行是矩阵D。那么接下来的n行就是矩阵W。所以有2n + 1
行。
这是解析它并将其放入变量的代码。
func readFile(path string) (int64, Matrix, Matrix) {
// open the file
f, _ := os.Open(path)
defer f.Close()
// init the new reader on the opened file
r := bufio.NewReader(f)
// we get the n value
line, _ := r.ReadString('\n')
splitedLine := strings.Fields(line)
tmp, _ := strconv.ParseInt(splitedLine[0], 10, 64)
n := int64(tmp)
// we init the matrix W and D
D := Matrix{}
D.matrix = make([][]int64, n)
for i, _ := range D.matrix {
D.matrix[i] = make([]int64, n)
}
W := Matrix{}
W.matrix = make([][]int64, n)
for i, _ := range W.matrix {
W.matrix[i] = make([]int64, n)
}
// loop on the n first element
iter := int64(0)
for iter < n {
// we get the n following elements
line, _ = r.ReadString('\n')
for index, ele := range strings.Split(line, ",") {
D.matrix[iter][index], _ = strconv.ParseInt(ele, 10, 64)
}
iter++
}
iter = 0
for iter < n {
// we get the n following elements
line, _ = r.ReadString('\n')
for index, ele := range strings.Split(line, ",") {
W.matrix[iter][index], _ = strconv.ParseInt(ele, 10, 64)
}
iter++
}
return n, W, D
}
W 的结果应该是这样的:
[ 0., 1., 2., 3., 1., 2., 3., 4., 2., 3., 4., 5.],
[ 1., 0., 1., 2., 2., 1., 2., 3., 3., 2., 3., 4.],
[ 2., 1., 0., 1., 3., 2., 1., 2., 4., 3., 2., 3.],
[ 3., 2., 1., 0., 4., 3., 2., 1., 5., 4., 3., 2.],
[ 1., 2., 3., 4., 0., 1., 2., 3., 1., 2., 3., 4.],
[ 2., 1., 2., 3., 1., 0., 1., 2., 2., 1., 2., 3.],
[ 3., 2., 1., 2., 2., 1., 0., 1., 3., 2., 1., 2.],
[ 4., 3., 2., 1., 3., 2., 1., 0., 4., 3., 2., 1.],
[ 2., 3., 4., 5., 1., 2., 3., 4., 0., 1., 2., 3.],
[ 3., 2., 3., 4., 2., 1., 2., 3., 1., 0., 1., 2.],
[ 4., 3., 2., 3., 3., 2., 1., 2., 2., 1., 0., 1.],
[ 5., 4., 3., 2., 4., 3., 2., 1., 3., 2., 1., 0.]
但是当我打印它时;它给了我:
[0 1 2 3 1 2 3 4 2 3 4 0]
[1 0 1 2 2 1 2 3 3 2 3 0]
[2 1 0 1 3 2 1 2 4 3 2 0]
[3 2 1 0 4 3 2 1 5 4 3 0]
[1 2 3 4 0 1 2 3 1 2 3 0]
[2 1 2 3 1 0 1 2 2 1 2 0]
[3 2 1 2 2 1 0 1 3 2 1 0]
[4 3 2 1 3 2 1 0 4 3 2 0]
[2 3 4 5 1 2 3 4 0 1 2 0]
[3 2 3 4 2 1 2 3 1 0 1 0]
[4 3 2 3 3 2 1 2 2 1 0 0]
[5 4 3 2 4 3 2 1 3 2 1 0]
我不知道为什么。
感谢您的回复。
知道 Reader.ReadString()
return 给你一个带有分隔符的 string
值。所以 r.ReadString('\n')
会 return 你一个带有尾随换行符的字符串。
并且当您在逗号处拆分字符串时,最后一部分将包含换行符,并且尝试从中解析数字将会失败,如本例所示:
line := "0,1,2\n"
for _, ele := range strings.Split(line, ",") {
fmt.Println(strconv.ParseInt(ele, 10, 64))
}
输出(在 Go Playground 上尝试):
0 <nil>
1 <nil>
0 strconv.ParseInt: parsing "2\n": invalid syntax
你虔诚地忽略了错误检查,不要那样做!正如您在上面的示例中看到的,检查并打印由 strconv.ParseInt()
编辑的错误 return 立即揭示了错误以及出了什么问题。
你可以做的是在尝试从中解析任何数字之前删除尾随的换行符,例如:
strconv.ParseInt(strings.TrimSpace(ele), 10, 64)
或者使用 bufio.Scanner
可以扫描行并自动切割尾随换行符。
我正在尝试解析这种形式的文件:
12
0,1,2,3,1,2,3,4,2,3,4,5
1,0,1,2,2,1,2,3,3,2,3,4
2,1,0,1,3,2,1,2,4,3,2,3
3,2,1,0,4,3,2,1,5,4,3,2
1,2,3,4,0,1,2,3,1,2,3,4
2,1,2,3,1,0,1,2,2,1,2,3
3,2,1,2,2,1,0,1,3,2,1,2
4,3,2,1,3,2,1,0,4,3,2,1
2,3,4,5,1,2,3,4,0,1,2,3
3,2,3,4,2,1,2,3,1,0,1,2
4,3,2,3,3,2,1,2,2,1,0,1
5,4,3,2,4,3,2,1,3,2,1,0
0,5,2,4,1,0,0,6,2,1,1,1
5,0,3,0,2,2,2,0,4,5,0,0
2,3,0,0,0,0,0,5,5,2,2,2
4,0,0,0,5,2,2,10,0,0,5,5
1,2,0,5,0,10,0,0,0,5,1,1
0,2,0,2,10,0,5,1,1,5,4,0
0,2,0,2,0,5,0,10,5,2,3,3
6,0,5,10,0,1,10,0,0,0,5,0
2,4,5,0,0,1,5,0,0,0,10,10
1,5,2,0,5,5,2,0,0,0,5,0
1,0,2,5,1,4,3,5,10,5,0,2
1,0,2,5,1,0,3,0,10,0,2,0
第一行给出了矩阵的大小:n x n
接下来的n行是矩阵D。那么接下来的n行就是矩阵W。所以有2n + 1
行。
这是解析它并将其放入变量的代码。
func readFile(path string) (int64, Matrix, Matrix) {
// open the file
f, _ := os.Open(path)
defer f.Close()
// init the new reader on the opened file
r := bufio.NewReader(f)
// we get the n value
line, _ := r.ReadString('\n')
splitedLine := strings.Fields(line)
tmp, _ := strconv.ParseInt(splitedLine[0], 10, 64)
n := int64(tmp)
// we init the matrix W and D
D := Matrix{}
D.matrix = make([][]int64, n)
for i, _ := range D.matrix {
D.matrix[i] = make([]int64, n)
}
W := Matrix{}
W.matrix = make([][]int64, n)
for i, _ := range W.matrix {
W.matrix[i] = make([]int64, n)
}
// loop on the n first element
iter := int64(0)
for iter < n {
// we get the n following elements
line, _ = r.ReadString('\n')
for index, ele := range strings.Split(line, ",") {
D.matrix[iter][index], _ = strconv.ParseInt(ele, 10, 64)
}
iter++
}
iter = 0
for iter < n {
// we get the n following elements
line, _ = r.ReadString('\n')
for index, ele := range strings.Split(line, ",") {
W.matrix[iter][index], _ = strconv.ParseInt(ele, 10, 64)
}
iter++
}
return n, W, D
}
W 的结果应该是这样的:
[ 0., 1., 2., 3., 1., 2., 3., 4., 2., 3., 4., 5.],
[ 1., 0., 1., 2., 2., 1., 2., 3., 3., 2., 3., 4.],
[ 2., 1., 0., 1., 3., 2., 1., 2., 4., 3., 2., 3.],
[ 3., 2., 1., 0., 4., 3., 2., 1., 5., 4., 3., 2.],
[ 1., 2., 3., 4., 0., 1., 2., 3., 1., 2., 3., 4.],
[ 2., 1., 2., 3., 1., 0., 1., 2., 2., 1., 2., 3.],
[ 3., 2., 1., 2., 2., 1., 0., 1., 3., 2., 1., 2.],
[ 4., 3., 2., 1., 3., 2., 1., 0., 4., 3., 2., 1.],
[ 2., 3., 4., 5., 1., 2., 3., 4., 0., 1., 2., 3.],
[ 3., 2., 3., 4., 2., 1., 2., 3., 1., 0., 1., 2.],
[ 4., 3., 2., 3., 3., 2., 1., 2., 2., 1., 0., 1.],
[ 5., 4., 3., 2., 4., 3., 2., 1., 3., 2., 1., 0.]
但是当我打印它时;它给了我:
[0 1 2 3 1 2 3 4 2 3 4 0]
[1 0 1 2 2 1 2 3 3 2 3 0]
[2 1 0 1 3 2 1 2 4 3 2 0]
[3 2 1 0 4 3 2 1 5 4 3 0]
[1 2 3 4 0 1 2 3 1 2 3 0]
[2 1 2 3 1 0 1 2 2 1 2 0]
[3 2 1 2 2 1 0 1 3 2 1 0]
[4 3 2 1 3 2 1 0 4 3 2 0]
[2 3 4 5 1 2 3 4 0 1 2 0]
[3 2 3 4 2 1 2 3 1 0 1 0]
[4 3 2 3 3 2 1 2 2 1 0 0]
[5 4 3 2 4 3 2 1 3 2 1 0]
我不知道为什么。 感谢您的回复。
知道 Reader.ReadString()
return 给你一个带有分隔符的 string
值。所以 r.ReadString('\n')
会 return 你一个带有尾随换行符的字符串。
并且当您在逗号处拆分字符串时,最后一部分将包含换行符,并且尝试从中解析数字将会失败,如本例所示:
line := "0,1,2\n"
for _, ele := range strings.Split(line, ",") {
fmt.Println(strconv.ParseInt(ele, 10, 64))
}
输出(在 Go Playground 上尝试):
0 <nil>
1 <nil>
0 strconv.ParseInt: parsing "2\n": invalid syntax
你虔诚地忽略了错误检查,不要那样做!正如您在上面的示例中看到的,检查并打印由 strconv.ParseInt()
编辑的错误 return 立即揭示了错误以及出了什么问题。
你可以做的是在尝试从中解析任何数字之前删除尾随的换行符,例如:
strconv.ParseInt(strings.TrimSpace(ele), 10, 64)
或者使用 bufio.Scanner
可以扫描行并自动切割尾随换行符。