當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Logger.Info方法代碼示例

本文整理匯總了Golang中github.com/purstal/go-tieba-base/logs.Logger.Info方法的典型用法代碼示例。如果您正苦於以下問題:Golang Logger.Info方法的具體用法?Golang Logger.Info怎麽用?Golang Logger.Info使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/purstal/go-tieba-base/logs.Logger的用法示例。


在下文中一共展示了Logger.Info方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: LoadStrings

func LoadStrings(file *os.File, set *map[string]struct{}, logger *logs.Logger) error {
	bytes, err := ReadAll(file)
	if err != nil {
		return err
	}

	lines := split([]rune(string(bytes)), []rune{'\n', ' '})

	newSet := map[string]struct{}{}

	oldSet := map[string]struct{}{}

	for k, v := range *set {
		oldSet[k] = v //複製一遍
	}

	var added []string

	for _, _line := range lines {
		var line string
		if line = strings.TrimSpace(string(_line)); line == "" {
			continue
		}
		newSet[line] = struct{}{}
		if _, exist := oldSet[line]; !exist {
			added = append(added, line)
		}
		delete(oldSet, line)
	}

	*set = newSet

	var updateInfo string = fmt.Sprintf("更新關鍵詞(%s):", file.Name())
	if len(added) > 0 {
		updateInfo = updateInfo + "\n[+]"
		for _, str := range added {
			updateInfo = updateInfo + str + " "
		}
		updateInfo = strings.TrimRight(updateInfo, " ")
	}
	if len(oldSet) > 0 {
		updateInfo = updateInfo + "\n[-]"
		for str, _ := range oldSet {
			updateInfo = updateInfo + str + " "
		}
		updateInfo = strings.TrimRight(updateInfo, " ")
	}
	logger.Info(updateInfo)

	return nil
}
開發者ID:qida,項目名稱:tieba-post-deleter,代碼行數:51,代碼來源:string.go

示例2: LoadExps

func LoadExps(file *os.File, exps *[]RegexpKeyword, logger *logs.Logger) error {

	bytes, err := ReadAll(file)
	if err != nil {
		return err
	}

	lines := strings.Split(string(bytes), "\n")

	oldExps := make(map[string]RegexpKeyword)

	for _, exp := range *exps {
		if exp.BanFlag {
			oldExps["$ban "+exp.Rx.String()] = exp
		} else {
			oldExps[exp.Rx.String()] = exp
		}
	}

	newExps := make(map[string]RegexpKeyword)
	var addedExps []string

	for lineNo, line := range lines {
		line = strings.TrimRightFunc(line, func(r rune) bool {
			return r == '\n' || r == '\r'
		})
		if line == "" {
			continue
		}
		if exp, exist := oldExps[line]; exist {
			newExps[line] = exp
			delete(oldExps, line)
		} else {
			var banFlag bool
			var newExp *regexp.Regexp
			var err error
			if banFlag = strings.HasPrefix(line, "$ban "); banFlag {
				newExp, err = regexp.Compile(strings.TrimLeft(line, "$ban "))
			} else {
				newExp, err = regexp.Compile(line)
			}
			if err != nil {
				logs.Error(fmt.Sprintf("不正確的關鍵詞(第%d行),跳過.", lineNo), err)
			} else {
				newExps[line] = RegexpKeyword{banFlag, newExp}
				addedExps = append(addedExps, line)
			}

		}
	}

	newExpSlice := make([]RegexpKeyword, 0, len(newExps))

	for _, exp := range newExps {
		newExpSlice = append(newExpSlice, exp)
	}

	*exps = newExpSlice

	var updateInfo string = fmt.Sprintf("更新關鍵詞(%s):\n", file.Name())
	for _, exp := range addedExps {
		updateInfo = updateInfo + "[+] " + exp + "\n"
	}
	for _, exp := range oldExps {
		if exp.BanFlag {
			updateInfo = updateInfo + "[-] $ban" + exp.Rx.String() + "\n"
		} else {
			updateInfo = updateInfo + "[-] " + exp.Rx.String() + "\n"
		}
	}
	updateInfo = strings.TrimSuffix(updateInfo, "\n")
	logger.Info(updateInfo)

	//logger.Debug("現在的關鍵詞:", newExpSlice, ".")

	return nil
}
開發者ID:qida,項目名稱:tieba-post-deleter,代碼行數:77,代碼來源:regexp.go


注:本文中的github.com/purstal/go-tieba-base/logs.Logger.Info方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。