首页 > 解决方案 > 破坏对编码 pkg 的依赖。代码从一天到另一天都不起作用。升级失败?(编辑:不!失败的用户。请看我的回答)

问题描述

我是 Golang 的新手,正在开发一个网络抓取程序。昨晚我正在运行我的程序,一切都很好。我的程序使用“go run xyz.go”从源代码或构建版本($ ./xyz.exe)运行

今天早上我醒来发现一个明显的依赖问题,我还没有弄清楚。昨晚构建的程序(./xyz.exe)仍在运行,但是当我今天尝试使用“go run xyz.go”运行源代码时,我得到以下结果:

"$ 去运行 xyz.go

go build golang.org/x/text/encoding: 在 C:\Users\admin\Dropbox\gowork\pkg\mod\golang.org\x\text@v0.3.7\encoding 中没有非测试 Go 文件

go build golang.org/x/text/transform:C:\Users\admin\Dropbox\gowork\pkg\mod\golang.org\x\text@v0.3.7\transform 中没有非测试 Go 文件

golang.org/x/net/html/atom

........\pkg\mod\golang.org\x\net@v0.0.0-20210916014120-12bc252f5db8\html\atom\atom.go:27:26:未定义:atomText ...... ..\pkg\mod\golang.org\x\net@v0.0.0-20210916014120-12bc252f5db8\html\atom\atom.go:30:9: undefined: atomText ........\pkg\mod \golang.org\x\net@v0.0.0-20210916014120-12bc252f5db8\html\atom\atom.go:34:9: undefined: atomText ........\pkg\mod\golang.org\x \net@v0.0.0-20210916014120-12bc252f5db8\html\atom\atom.go:58:29:未定义:maxAtomLen ........\pkg\mod\golang.org\x\net@v0.0.0 -20210916014120-12bc252f5db8\html\atom\atom.go:61:11: 未定义: hash0 ........\pkg\mod\golang.org\x\net@v0.0.0-20210916014120-12bc252f5db8\html \atom\atom.go:62:10: undefined: table ........\pkg\mod\golang.org\x\net@v0.0.0-20210916014120-12bc252f5db8\html\atom\atom.go :65:10:未定义:表

github.com/andybalholm/cascadia

........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:10:9: undefined: tagSelector ........\pkg\mod\github .com\andybalholm\cascadia@v1.2.0\serialize.go:14:9: undefined: idSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go :18:9: undefined: classSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:22:9: undefined: attrSelector ...... ..\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:32:9: undefined: relativePseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia @v1.2.0\serialize.go:35:9: undefined: containsPseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:42:9: 未定义: regexpPseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:49:9: undefined: nthPseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:75:9: undefined: onlyChildPseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1 .2.0\serialize.go:81:9: undefined: inputPseudoClassSelector ........\pkg\mod\github.com\andybalholm\cascadia@v1.2.0\serialize.go:81:9: 错误太多

golang.org/x/text/internal/language

........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\compact.go:12:23: undefined: Tag ........\pkg \mod\golang.org\x\text@v0.3.7\internal\language\compact.go:23:32: undefined: Tag ........\pkg\mod\golang.org\x\text @v0.3.7\internal\language\compose.go:15:6: undefined: Tag ........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\compose .go:23:26: undefined: Tag ........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\compose.go:56:28: undefined: Tag ........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\coverage.go:9:24: undefined: Language ........\pkg \mod\golang.org\x\text@v0.3.7\internal\language\match.go:17:10: undefined: Tag ........\pkg\mod\golang.org\x\text @v0.3.7\internal\language\match.go:17:35: undefined: Language ........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\match .go:23:10: 未定义:标签 ........\pkg\mod\golang.org\x\text@v0.3.7\internal\language\match.go:23:37: undefined: Script ........\pkg\mod\golang.org\x \text@v0.3.7\internal\language\match.go:23:37:错误太多”

我试图通过升级到最新版本的 Golang 来解决这个问题。不确定这是否让事情变得更糟。

我正在使用 encoding/csv 包。我的 IDE 是 Visual Sudio Code。这是我的代码:

package main

import (
    "encoding/csv" // Problem seems to be with this package
    "fmt"
    "log"
    "net"
    "net/http"
    "os"
    "strings"
    "time"

    "github.com/gocolly/colly"
)

func main() {

    fName := "FOOT-live-data.csv"
    file, err := os.OpenFile(fName, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
    if err != nil {
        log.Fatalf("No se pudo crear archivo, error: %q", err)
        return
    }
    defer file.Close()

    writer := csv.NewWriter(file) // Package encoding/csv is used here
    defer writer.Flush()
    
    liga := ""
    start := time.Now()
    cons := 0
    eventodds := make([]string, 3, 5)
    var data [][]string

    c := colly.NewCollector()
    
    c.OnHTML(`div#USInplay-tab-FOOT div.table-row.row-wrap`, func(e *colly.HTMLElement) {

        if e.DOM.Children().Length() == 1 {
            if liga != e.ChildText(`div.ev-type-header`) {
                liga = e.ChildText(`div.ev-type-header`)
            }
        } else {
            cons = cons + 1
            timestamp := time.Now().Round(time.Second)
            eventid := e.Attr("data-mkt_id")
            eventinfo := strings.Split(e.ChildText(`div[class="team-score"]`), "\n")
            eventtime := e.ChildText(`span.clock_mode_forward`)
            eventperiod := e.ChildText(`span.period`)

            e.ForEach(`div.inplay td.seln`, func(i int, elem *colly.HTMLElement) {
                eventodds[i] = elem.ChildText(`span.dec`)
            })

            data = append(data, []string{
                timestamp.Format(time.RubyDate),
                "WPlay",
                liga,
                eventid,
                eventinfo[1] + " - " + eventinfo[4],
                eventinfo[0] + "-" + eventinfo[3],
                eventtime,
                eventperiod,
                eventodds[0],
                eventodds[1],
                eventodds[2],
            })

        }

    })

    c.Visit("https://apuestas.wplay.co/es")

    writer.WriteAll(data)

    log.Printf("Scraping finished, check file %q for results\n", fName)

    secs := time.Since(start).Seconds()
    fmt.Printf("Tiempo total: %v segs", secs)
}

标签: go

解决方案


我设法弄清楚了这个奇怪的情况!我在删除我的愚蠢问题或自己回答以帮助处于类似情况的其他人之间进行了辩论。我决定咬紧牙关,自己回答。

该问题确实与损坏的依赖关系有关,但与编码包无关。问题的根本原因是我对 Github 的笨拙使用。

我主要在这台计算机上工作,我创建了一个 Github 代表来保存我的工作并将其复制到两台计算机上,一台笔记本电脑用于道路和一台旧 Mac。

几周前,我出差了,一晚忙于我的项目。我在那台机器上的 Colly 包有问题,所以我从 src 和 pkg 文件夹中删除了它,这些文件夹与 Github 代表同步。然后,我机械地和“无神经地”将我的工作与 Github 同步,就像我在旅程结束时所做的那样。

回到我常用的电脑上,我确实做了一些工作,并与我的 Guthub 代表同步。当我收到警告说在“拉动”或忽略来自 Github 代表的最新版本之前不要“推动”我的工作时,我在首先从代表“拉动”之前没有再考虑它。

繁荣!从我在路上的笔记本电脑上删除的 Colly 文件夹通过 Github 一直进入这台机器。它在这台机器上的 Colly 文件夹上弄得一团糟,我仍在试图解开。

我还意识到将 bin、pkg 和 src 文件夹与 Github 同步是没有意义的,因为只有后者包含您关心的实际代码,如果内容不存在,其他两个将在本地填充;它们特定于您正在处理的机器和架构。我现在几乎可以肯定首先在我的笔记本电脑上造成了这个问题。

这证实了你从错误中学到的比从成功中学到更多的说法!

再次,我很抱歉在没有用尽所有资源的情况下发布了这个问题。我希望它的结论是有帮助的。


推荐阅读