繁体   English   中英

Golang:在文件中跳过空白

[英]Golang: Skipping Whitespace in a file

在Go中读取文件时,我试图跳过所有空白; 但是,我在寻找正确的方法来执行此操作时遇到了问题。 任何援助将不胜感激

file, err := os.Open(filename) // For read access.
        this.file = file
        if err != nil {
                log.Fatal(err)
        }
//skip white space

  c := make([]byte, 1)

    char, err := this.file.Read(c)

    //skip white space
    for {
            //catch unintended errors
            if err != nil && err != io.EOF {
                    panic(err)
            }
            if err == io.EOF || !unicode.IsSpace(int(c)) {
                    break
            }
            //get next
            char, err := this.file.Read(c)
    }

我只是在尝试为文件创建扫描程序,以便一次读取一个字符并忽略空格

编辑

我使用bufio.Reader进行了一些更改。 但是我仍然陷入一个问题,即逐个字符读取文件的正确方法是什么,以便可以将其与诸如“ A”之类的特定符号进行比较,但也可以忽略空格,即unicode.isSpace(rune)

char, size, err := this.reader.ReadRune()
    //skip white space and comments
    for {
            //catch unintended errors
            if err != nil && err != io.EOF {
                    panic(err)
            }
            if err == io.EOF {
                    break
            }

            //skip it when their is no data or a space
            if size != 0 && char == '{' {
                    //Ignore Comments
                    //Documentation specifies no nested comments
                    for char != '}' {
                            char, size, err = this.reader.ReadRune()
                    }
            } else if !unicode.IsSpace(char) {
                    break
            }

            // Do something with the byte
            fmt.Print(char)

            //get next
            char, size, err = this.reader.ReadRune()
    }

除非我误解了您的问题,否则在遇到空格时您似乎希望continue声明。

c := make([]byte, 100)

n, err := this.file.Read(c)

//skip white space
for {
    //catch unintended errors
    if err != nil && err != io.EOF {
        panic(err)
    }
    if err == io.EOF {
        break
    }

    for i := 0; i < n; i++ {
        ch := c[i]

        switch ch {
        case '{': // Do something
        case '}': // Do something else
        default:
            if unicode.IsSpace(int(ch)) {
                continue
            }
            // Do whatever
        }
    }

        //get next
    n, err = this.file.Read(c)
}

我不知道为什么您一次要读取一个字节,但是如果有意的话,我会以这种方式保留它。 至少,我认为您想读取完整的unicode字符而不是单个字节。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM