>  기사  >  백엔드 개발  >  Go의 for 루프에서 인터페이스 목록을 어떻게 반환하나요?

Go의 for 루프에서 인터페이스 목록을 어떻게 반환하나요?

王林
王林앞으로
2024-02-09 12:10:18330검색

如何从 Go 中的 for 循环返回接口列表?

Go 언어에서는 for 루프를 통해 배열, 슬라이스, 맵과 같은 데이터 구조를 탐색할 수 있습니다. 그러나 루프에서 인터페이스 목록을 반환해야 하는 경우도 있습니다. 인터페이스는 여러 구체적인 유형을 나타낼 수 있는 추상 유형이기 때문에 이는 일반적인 요구 사항입니다. 이 기사에서는 Go에서 for 루프를 사용하여 인터페이스 목록을 반환하는 방법을 소개합니다. 먼저 Go의 인터페이스 유형과 유형 주장의 개념을 이해해야 합니다.

질문 내용

go의 for 루프에서 인터페이스 목록을 어떻게 반환하나요? 다음과 같은 데이터가 있다고 가정합니다:

id 이름 프로젝트_유형
1 프로젝트_이름 1
2 프로젝트_이름 1
3 프로젝트_이름 1
4 프로젝트_이름 2
5 프로젝트_이름 2
6 프로젝트_이름 3
7 프로젝트_이름 3
8 프로젝트_이름 3
9 프로젝트_이름 4
10 프로젝트_이름 4

다음 go 코드를 사용하여 project_type=1 및 project_type=2의 두 목록을 얻을 수 있습니다.

으아악

하지만 이제 project_type의 데이터는 的json[{"project_type":1,"name":"something else"},{"project_type":2,"name":"something else"},{ "project_type":3,"name":"something else"},{"project_type":4,"name":"something else"}]이고, project_type은 2보다 큽니다. 인터페이스 목록을 가져와야 합니다.{} 다음 코드를 다시 작성하려고 하는데 다음에 무엇을 써야 할지, 어떻게 반환해야 할지 모르겠습니다. for 루프의 인터페이스 목록이 이동 중인가요? 제안해 주셔서 감사합니다.

func (d *db) projectlist(type, uid string, size uint64) (interface{}, interface{}, error) {
    type resp struct {
        name            string  `json:"name"`
        id             string  `json:"id"`
        projecttype    string  `json:"project_type"`

    }

    var project_type_1 []*resp
    var project_type_2 []*resp

    sql = fmt.sprintf(sql, where.string())
    _, err := d.ctx.db().selectbysql("select * from project where project_type=1 order by rand() limit 10").load(&project_type_1)

    _, err = d.ctx.db().selectbysql("select * from project where project_type=2 order by rand() limit 10").load(&project_type_2)
    return project_type_1, project_type_2, err
}

해결 방법

project_type당 10개의 결과를 원하는 경우(모두 10*n 결과):

으아악

모든 유형에 걸쳐 총 10개의 결과가 있는 경우:

으아악

위 내용은 Go의 for 루프에서 인터페이스 목록을 어떻게 반환하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제