Mam klasę, która pomaga mi odczytać plik CSV, i inną klasę, która tworzy obiekt dla każdej linii CSV, więc mogę uruchomić pewne akcje dla każdej linii osobno . używając tego do automatyzacji.Nie mogę przejść do następnej linii podczas odczytu pliku CSV
Z jakiegoś powodu po jednej linii zatrzymuje mój program ... to działało wcześniej, więc nie wiem co jest nie tak ..
to moja klasa czytelnik csv:
import java.io.File
import com.github.tototoshi.csv.CSVReader
import jxl.{Cell, Workbook}
import scala.collection.mutable
trait DataSource {
def read (fileName: String): Seq[Map[String, String]]
}
object CsvDataSource extends DataSource {
import com.github.tototoshi.csv.CSVFormat
import com.github.tototoshi.csv.Quoting
import com.github.tototoshi.csv.QUOTE_MINIMAL
implicit object VATBoxFormat extends CSVFormat {
val delimiter: Char = '\t'
val quoteChar: Char = '"'
val escapeChar: Char = '"'
val lineTerminator: String = "\r\n"
val quoting: Quoting = QUOTE_MINIMAL
val treatEmptyLineAsNil: Boolean = false
}
override def read(file: String): Seq[Map[String, String]] = {
val reader = CSVReader.open(file, "UTF-16")(VATBoxFormat)
reader.iteratorWithHeaders.toSeq
}
}
to PurchaseInfo Klasa, która tworzy obiekt o każdej linii csv:
case class PurchaseInfo(
something1: String,
something2: String,
something3: String,
something4: String) {
}
object PurchaseInfo {
private def changeDateFormat(dateInString: String): String = {
//System.out.println(dateInString)
val formatter: SimpleDateFormat = new SimpleDateFormat("MMM dd, yyyy")
val formatter2: SimpleDateFormat = new SimpleDateFormat("dd/MM/yyyy")
val date: Date = formatter.parse(dateInString)
return formatter2.format(date).toString
}
def fromDataSource (ds: DataSource)(fileName: String): Seq[PurchaseInfo] = {
ds.read(fileName).map { c =>
PurchaseInfo(
something1 = c("Supplier Address Street Number"),
something2 = c("Supplier Address Route"),
something3 = c("Supplier Address Locality"),
something4 = c("Supplier Address Postal Code")
)
}
}
}
teraz w klasie gdzie mogę wykonywać wszystkie czynności jest jedna metoda zwana insertData że dostać sekwencję kupna- haseInfos i wywołuje inny sposób z każdym purchaseInfo wewnątrz tego nast ....
def insertData (purchaseInfos: Seq[PurchaseInfo]) = {
//logging in and then getting directed to the right path (where we start the invoices automation)
login()
val res = purchaseInfos.map { case purchaseInfo =>
println(purchaseInfo.invoiceNumber)
(purchaseInfo, Try(addInvoiceFlow(purchaseInfo)))
}
res
}
problemem jest to, że insertData wzywa addInvoiceFlow tylko jeden z pierwszym purchaseInfo i zatrzymuje ... dlaczego? Sprawdziłem i istnieje 34 linii, więc nie ma prob z pliku csv ..
ten jest napisany w języku Java Scala ale może pomóc też :)
Nie pokazujesz, jak zbudowany jest argument 'purchaseInfos' z' insertData'. Czy jesteś pewien, że w tej sekwencji jest więcej niż jeden wpis? – Tim