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 중국어 웹사이트의 기타 관련 기사를 참조하세요!