• 对文件的内容进行统计字母数字中文,并且显示每个结果


    package main
    
    import (
    	"bufio"
    	"fmt"
    	"io"
    	"log"
    	"os"
    )
    
    type Count struct {
    	Strcount int
    	Numcount int
    	Other    int
    	China    int
    }
    
    func main() {
    	filename := "./abc.txt"
    	file, err := os.Open(filename)
    	if err != nil {
    		log.Fatal(err)
    	}
    	var c Count
    	//返回带缓冲的reader
    	readre := bufio.NewReader(file)
    	for {
    		//// ReadString读取,直到输入中第一次出现delim,
    		//返回一个字符串,该字符串包含分隔符之前的数据,并包含分隔符。
    		//如果ReadString在找到分隔符之前遇到错误,
    		//它返回在错误之前读取的数据和错误本身(通常是io.EOF)。
    		// ReadString返回err != nil,当且仅当返回的数据没有结束
    		// delim 意思就是分割
    		str, err := readre.ReadString('
    ')
    		//开始遍历读取的str数据 str底层是byte字节数组
    		//我们要判断是不是中文 所以这里转成 rune UTF-8编码 大于255肯定是中文
    		for _, v := range []rune(str) {
    			switch {
    			case v >= 'a' && v <= 'z':
    				fallthrough
    			case v >= 'A' && v <= 'Z':
    				c.Strcount++
    			case v >= '0' && v <= '9':
    				c.Numcount++
    			case v > 255:
    				c.China++
    			default:
    				c.Other++
    			}
    		}
    		//文件读取结束 跳出循环
    		if err == io.EOF {
    			break
    		}
    		if err != nil {
    			log.Fatal(err)
    		}
    	}
    	fmt.Println("c.Numcoun=", c.Numcount)
    	fmt.Println("c.Strcount=", c.Strcount)
    	fmt.Println("c.China=", c.China)
    	fmt.Println("c.Other=", c.Other)
    }
    

      

  • 相关阅读:
    DES介绍
    jsp知识点
    浏览器地址传中文
    cookie
    null与“ ”的区别
    验证二叉查找树 · Validate Binary Search Tree
    二叉树中的最大路径和 · Binary Tree Maximum Path Sum
    最近公共祖先 · Lowest Common Ancestor
    平衡二叉树Balanced Binary Tree
    二叉树的最大/小/平衡 深度 depth of binary tree
  • 原文地址:https://www.cnblogs.com/egrep/p/10402246.html
Copyright © 2020-2023  润新知