Ваша логика предполагает, что длина a
всегда является правильным количеством для условной итерации.Игровая площадка, которую @FatchulAmin поделился в комментарии к ответу @EdChan, выявила проблему, когда a
больше b
или наоборот, вы получите ошибку «index out of range», потому что меньший срез больше не будет иметь индексовчтобы соответствовать большему.a[i].TransactionDate == b[i].TransactionDate
Для здравомыслия в этом случае вы должны выполнить проверку, чтобы найти наименьшее число для повторения, однако это не позволит вам полностью проверить все самые большие срезы.
Я предлагаю объединить фрагменты, затем найти самый большой и наименьший диапазон и выполнить цикл, чтобы удалить то, что вы хотите от объединенного.ПРИМЕЧАНИЕ: @EdChan правильно использовать одну структуру, так как они все одинаковы.
type FooBar struct {
TransactionDate string
TotalAmount string
TotalTransaction string
}
type FooBarSlice []FooBar // this is used as a receiver on func Remove
func compareReplace(a []FooBar, b []FooBar) []FooBar {
var c FooBarSlice
c = append(a, b...)
var largerSlice []FooBar
var smallerSlice []FooBar
if len(a) <= len(b) {
largerSlice = b
smallerSlice = a
} else {
largerSlice = a
smallerSlice = b
}
for _, v := range smallerSlice {
for j := 0; j < len(largerSlice); j++ {
if largerSlice[j].TransactionDate == v.TransactionDate && largerSlice[j].TotalTransaction == "0" {
c.Remove(j)
}
}
}
return c
}
Полный рабочий пример: https://play.golang.org/p/iyUYtXlDG54