Convert string array with 3 pieces of information into an array of objects - JAVA
I am trying to convert an array that has three pieces of customer information in each bin:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
I have a class (Customers) that includes a constructor to make a customer with the first name, the last name, and an email.
String customerList = "";
for (int i = 0; i < csv.length; i++)
customerList += csv[i];
String customers = customerList.split(",");
Customer customs = new Customer[(customers.length / 3)];
for (int i = 0; i < customers.length / 3; i += 3)
customs[i] = new Customer(customers[i], customers[i + 1], customers[i + 2]);
System.out.println(customs[0].getFirst_name());
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
This gets me almost to where I need to be, however there is one small problem-- when the information is being stored in the array, it does not consider the comma in the original array as one of the commas I am trying to use as a split. Here is what the code above gives me:
Email Creator
=========================
jimmy
johnson
jjohnson@gmail.comJoe
As you can see, the first bits of information is correct, but Joe (the first name of the second person) is lumped in with the first customer.
java
add a comment |
I am trying to convert an array that has three pieces of customer information in each bin:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
I have a class (Customers) that includes a constructor to make a customer with the first name, the last name, and an email.
String customerList = "";
for (int i = 0; i < csv.length; i++)
customerList += csv[i];
String customers = customerList.split(",");
Customer customs = new Customer[(customers.length / 3)];
for (int i = 0; i < customers.length / 3; i += 3)
customs[i] = new Customer(customers[i], customers[i + 1], customers[i + 2]);
System.out.println(customs[0].getFirst_name());
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
This gets me almost to where I need to be, however there is one small problem-- when the information is being stored in the array, it does not consider the comma in the original array as one of the commas I am trying to use as a split. Here is what the code above gives me:
Email Creator
=========================
jimmy
johnson
jjohnson@gmail.comJoe
As you can see, the first bits of information is correct, but Joe (the first name of the second person) is lumped in with the first customer.
java
add a comment |
I am trying to convert an array that has three pieces of customer information in each bin:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
I have a class (Customers) that includes a constructor to make a customer with the first name, the last name, and an email.
String customerList = "";
for (int i = 0; i < csv.length; i++)
customerList += csv[i];
String customers = customerList.split(",");
Customer customs = new Customer[(customers.length / 3)];
for (int i = 0; i < customers.length / 3; i += 3)
customs[i] = new Customer(customers[i], customers[i + 1], customers[i + 2]);
System.out.println(customs[0].getFirst_name());
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
This gets me almost to where I need to be, however there is one small problem-- when the information is being stored in the array, it does not consider the comma in the original array as one of the commas I am trying to use as a split. Here is what the code above gives me:
Email Creator
=========================
jimmy
johnson
jjohnson@gmail.comJoe
As you can see, the first bits of information is correct, but Joe (the first name of the second person) is lumped in with the first customer.
java
I am trying to convert an array that has three pieces of customer information in each bin:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
I have a class (Customers) that includes a constructor to make a customer with the first name, the last name, and an email.
String customerList = "";
for (int i = 0; i < csv.length; i++)
customerList += csv[i];
String customers = customerList.split(",");
Customer customs = new Customer[(customers.length / 3)];
for (int i = 0; i < customers.length / 3; i += 3)
customs[i] = new Customer(customers[i], customers[i + 1], customers[i + 2]);
System.out.println(customs[0].getFirst_name());
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
This gets me almost to where I need to be, however there is one small problem-- when the information is being stored in the array, it does not consider the comma in the original array as one of the commas I am trying to use as a split. Here is what the code above gives me:
Email Creator
=========================
jimmy
johnson
jjohnson@gmail.comJoe
As you can see, the first bits of information is correct, but Joe (the first name of the second person) is lumped in with the first customer.
java
java
asked Nov 12 at 20:33
William Loveless
155
155
add a comment |
add a comment |
7 Answers
7
active
oldest
votes
I think this was what you wanted to achieve,
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length ; i++)
String customerDetails = csv[i].split(",");
customs[i] = new Customer(customerDetails[0].trim(), customerDetails[1].trim(), customerDetails[2].trim());
System.out.println(customs[0].getFirst_name()));
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
add a comment |
Calling
customerList += csv[i];
will give you a String that looks like
jimmy ,johnson,jjohnson@gmail.comJoe,Donald,Joe_Donald@donald.orgARTHUR,THOMPSON,ARTHUR@thompson.org
There's probably multiple ways to fix it, but I would try adding a comma after you concatenate each entry from the csv array:
customerList += csv[i] + ",";
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
add a comment |
Why do you need String customerList = "";
?
You can get the customs array like this:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length; i++)
String splitted = csv[i].split(",");
customs[i] = new Customer(splitted[0].trim(), splitted[1].trim(), splitted[2].trim());
add a comment |
Using Streams?
List<Customer> customer = Arrays.stream(customerList).map(
s->
String items = s.split(",");
return new Customer(items[0], items[1], items[2]);
}.collect(Collectors.toList());
add a comment |
I would start by overriding toString
in Customer
. You didn't post your version of Customer
, but that might look like
public class Customer
private String firstName;
private String lastName;
private String email;
public Customer(String first, String last, String email)
this.firstName = first.trim();
this.lastName = last.trim();
this.email = email.trim();
@Override
public String toString()
return String.format("first: %s, last: %s, email: %s", firstName, lastName, email);
Then you might use String.split
and Arrays.stream
and map your entries to Customer
instances like
String csv = " jimmy ,johnson,jjohnson@gmail.com", "Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org" ;
List<Customer> customs = Arrays.stream(csv).map(s -> s.split("\s*,\s*"))
.map(t -> new Customer(t[0], t[1], t[2])).collect(Collectors.toList());
for (Customer c : customs)
System.out.println(c);
And I get
first: jimmy, last: johnson, email: jjohnson@gmail.com
first: Joe, last: Donald, email: Joe_Donald@donald.org
first: ARTHUR, last: THOMPSON, email: ARTHUR@thompson.org
add a comment |
Here's a suggestion for you, a couple of things to point out:
- I'm using a List instead of an array, a list can grow dynamically
and you don't need to specify the size up front, it's also a bit
easier to work with than an array. - Use a foreach loop instead of standard for, you don't need the index
so a foreach is perfect - When splitting the line, just check you get the expected number of
parts, perhaps treat the others as errors, so safeguard yourself
later when you expect to find certain things in certain spots. - The trim lets you get rid of whitespace, it's always good to clean
the data as soon as you can so you don't get junk filtering through
your application. - Consider using Lombok, it gives you nice annotations to generate
accessor methods, toString etc
sample code:
public static void main(String args) throws IOException
String csv =
" jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org"
;
// use a List rather than array, so it can grow dynamically
List<Customer> customers = new ArrayList<Customer>();
for (String line : csv)
System.out.println("Processing line: " + line);
String parts = line.split(",");
if (parts.length != 3)
System.out.println("Expected to find 3 parts in the line, but got " + parts.length);
// construct the customer, notice the .trim() to remove any whitespace
Customer customer = new Customer(parts[0].trim(), parts[1].trim(), parts[2].trim());
customers.add(customer);
System.out.println("Printing out customer list:");
// loop through the customers and print them out
for (Customer c : customers)
System.out.println("firstName: " + c.firstName);
System.out.println("lastName: " + c.lastName);
System.out.println("email: " + c.email);
System.out.println("n");
static class Customer
// accessors removed, consider using Lombok for @Data, @Getter, @Setter etc
String firstName;
String lastName;
String email;
public Customer(String firstName, String lastName, String email)
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
This is the output I get, which I believe is what you're looking for
Processing line: jimmy ,johnson,jjohnson@gmail.com
Processing line: Joe,Donald,Joe_Donald@donald.org
Processing line: ARTHUR,THOMPSON,ARTHUR@thompson.org
Printing out customer list:
firstName: jimmy
lastName: johnson
email: jjohnson@gmail.com
firstName: Joe
lastName: Donald
email: Joe_Donald@donald.org
firstName: ARTHUR
lastName: THOMPSON
email: ARTHUR@thompson.org
Good luck!
add a comment |
I think your best bet here is to treat each element of your csv array as a distinct customer. There's no need to concatenate them all into one big string.
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int cidx = 0; cidx < csv.length; cidx++)
String fields = csv[cidx].split(",");
customs[cidx++] = new Customer(
fields.length>0 ? fields[0].trim() : null,
fields.length>1? fields[1].trim() : null,
fields.length>2? fields[2].trim() : null);
for (Customer custom : customs)
System.out.println("first="+custom.getFirst_name() + ", last="+custom.getLast_name()+", email="+custom.getEmail());
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53269689%2fconvert-string-array-with-3-pieces-of-information-into-an-array-of-objects-jav%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
7 Answers
7
active
oldest
votes
7 Answers
7
active
oldest
votes
active
oldest
votes
active
oldest
votes
I think this was what you wanted to achieve,
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length ; i++)
String customerDetails = csv[i].split(",");
customs[i] = new Customer(customerDetails[0].trim(), customerDetails[1].trim(), customerDetails[2].trim());
System.out.println(customs[0].getFirst_name()));
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
add a comment |
I think this was what you wanted to achieve,
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length ; i++)
String customerDetails = csv[i].split(",");
customs[i] = new Customer(customerDetails[0].trim(), customerDetails[1].trim(), customerDetails[2].trim());
System.out.println(customs[0].getFirst_name()));
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
add a comment |
I think this was what you wanted to achieve,
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length ; i++)
String customerDetails = csv[i].split(",");
customs[i] = new Customer(customerDetails[0].trim(), customerDetails[1].trim(), customerDetails[2].trim());
System.out.println(customs[0].getFirst_name()));
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
I think this was what you wanted to achieve,
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length ; i++)
String customerDetails = csv[i].split(",");
customs[i] = new Customer(customerDetails[0].trim(), customerDetails[1].trim(), customerDetails[2].trim());
System.out.println(customs[0].getFirst_name()));
System.out.println(customs[0].getLast_name());
System.out.println(customs[0].getEmail());
answered Nov 12 at 20:44
Sand
1,108114
1,108114
add a comment |
add a comment |
Calling
customerList += csv[i];
will give you a String that looks like
jimmy ,johnson,jjohnson@gmail.comJoe,Donald,Joe_Donald@donald.orgARTHUR,THOMPSON,ARTHUR@thompson.org
There's probably multiple ways to fix it, but I would try adding a comma after you concatenate each entry from the csv array:
customerList += csv[i] + ",";
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
add a comment |
Calling
customerList += csv[i];
will give you a String that looks like
jimmy ,johnson,jjohnson@gmail.comJoe,Donald,Joe_Donald@donald.orgARTHUR,THOMPSON,ARTHUR@thompson.org
There's probably multiple ways to fix it, but I would try adding a comma after you concatenate each entry from the csv array:
customerList += csv[i] + ",";
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
add a comment |
Calling
customerList += csv[i];
will give you a String that looks like
jimmy ,johnson,jjohnson@gmail.comJoe,Donald,Joe_Donald@donald.orgARTHUR,THOMPSON,ARTHUR@thompson.org
There's probably multiple ways to fix it, but I would try adding a comma after you concatenate each entry from the csv array:
customerList += csv[i] + ",";
Calling
customerList += csv[i];
will give you a String that looks like
jimmy ,johnson,jjohnson@gmail.comJoe,Donald,Joe_Donald@donald.orgARTHUR,THOMPSON,ARTHUR@thompson.org
There's probably multiple ways to fix it, but I would try adding a comma after you concatenate each entry from the csv array:
customerList += csv[i] + ",";
answered Nov 12 at 20:38
Mike
1,278717
1,278717
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
add a comment |
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
This works for the first customer, but then the first name of the second customer in the array is "'." which is incorrect
– William Loveless
Nov 12 at 20:45
I don't follow...when I tried this I got customers array =
[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
I don't follow...when I tried this I got customers array =
[ jimmy , johnson, jjohnson@gmail.com, Joe, Donald, Joe_Donald@donald.org, ARTHUR, THOMPSON, ARTHUR@thompson.org]
– Mike
Nov 12 at 20:54
add a comment |
Why do you need String customerList = "";
?
You can get the customs array like this:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length; i++)
String splitted = csv[i].split(",");
customs[i] = new Customer(splitted[0].trim(), splitted[1].trim(), splitted[2].trim());
add a comment |
Why do you need String customerList = "";
?
You can get the customs array like this:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length; i++)
String splitted = csv[i].split(",");
customs[i] = new Customer(splitted[0].trim(), splitted[1].trim(), splitted[2].trim());
add a comment |
Why do you need String customerList = "";
?
You can get the customs array like this:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length; i++)
String splitted = csv[i].split(",");
customs[i] = new Customer(splitted[0].trim(), splitted[1].trim(), splitted[2].trim());
Why do you need String customerList = "";
?
You can get the customs array like this:
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int i = 0; i < csv.length; i++)
String splitted = csv[i].split(",");
customs[i] = new Customer(splitted[0].trim(), splitted[1].trim(), splitted[2].trim());
answered Nov 12 at 20:45
forpas
8,3961419
8,3961419
add a comment |
add a comment |
Using Streams?
List<Customer> customer = Arrays.stream(customerList).map(
s->
String items = s.split(",");
return new Customer(items[0], items[1], items[2]);
}.collect(Collectors.toList());
add a comment |
Using Streams?
List<Customer> customer = Arrays.stream(customerList).map(
s->
String items = s.split(",");
return new Customer(items[0], items[1], items[2]);
}.collect(Collectors.toList());
add a comment |
Using Streams?
List<Customer> customer = Arrays.stream(customerList).map(
s->
String items = s.split(",");
return new Customer(items[0], items[1], items[2]);
}.collect(Collectors.toList());
Using Streams?
List<Customer> customer = Arrays.stream(customerList).map(
s->
String items = s.split(",");
return new Customer(items[0], items[1], items[2]);
}.collect(Collectors.toList());
answered Nov 12 at 20:44
matt
4,2441923
4,2441923
add a comment |
add a comment |
I would start by overriding toString
in Customer
. You didn't post your version of Customer
, but that might look like
public class Customer
private String firstName;
private String lastName;
private String email;
public Customer(String first, String last, String email)
this.firstName = first.trim();
this.lastName = last.trim();
this.email = email.trim();
@Override
public String toString()
return String.format("first: %s, last: %s, email: %s", firstName, lastName, email);
Then you might use String.split
and Arrays.stream
and map your entries to Customer
instances like
String csv = " jimmy ,johnson,jjohnson@gmail.com", "Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org" ;
List<Customer> customs = Arrays.stream(csv).map(s -> s.split("\s*,\s*"))
.map(t -> new Customer(t[0], t[1], t[2])).collect(Collectors.toList());
for (Customer c : customs)
System.out.println(c);
And I get
first: jimmy, last: johnson, email: jjohnson@gmail.com
first: Joe, last: Donald, email: Joe_Donald@donald.org
first: ARTHUR, last: THOMPSON, email: ARTHUR@thompson.org
add a comment |
I would start by overriding toString
in Customer
. You didn't post your version of Customer
, but that might look like
public class Customer
private String firstName;
private String lastName;
private String email;
public Customer(String first, String last, String email)
this.firstName = first.trim();
this.lastName = last.trim();
this.email = email.trim();
@Override
public String toString()
return String.format("first: %s, last: %s, email: %s", firstName, lastName, email);
Then you might use String.split
and Arrays.stream
and map your entries to Customer
instances like
String csv = " jimmy ,johnson,jjohnson@gmail.com", "Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org" ;
List<Customer> customs = Arrays.stream(csv).map(s -> s.split("\s*,\s*"))
.map(t -> new Customer(t[0], t[1], t[2])).collect(Collectors.toList());
for (Customer c : customs)
System.out.println(c);
And I get
first: jimmy, last: johnson, email: jjohnson@gmail.com
first: Joe, last: Donald, email: Joe_Donald@donald.org
first: ARTHUR, last: THOMPSON, email: ARTHUR@thompson.org
add a comment |
I would start by overriding toString
in Customer
. You didn't post your version of Customer
, but that might look like
public class Customer
private String firstName;
private String lastName;
private String email;
public Customer(String first, String last, String email)
this.firstName = first.trim();
this.lastName = last.trim();
this.email = email.trim();
@Override
public String toString()
return String.format("first: %s, last: %s, email: %s", firstName, lastName, email);
Then you might use String.split
and Arrays.stream
and map your entries to Customer
instances like
String csv = " jimmy ,johnson,jjohnson@gmail.com", "Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org" ;
List<Customer> customs = Arrays.stream(csv).map(s -> s.split("\s*,\s*"))
.map(t -> new Customer(t[0], t[1], t[2])).collect(Collectors.toList());
for (Customer c : customs)
System.out.println(c);
And I get
first: jimmy, last: johnson, email: jjohnson@gmail.com
first: Joe, last: Donald, email: Joe_Donald@donald.org
first: ARTHUR, last: THOMPSON, email: ARTHUR@thompson.org
I would start by overriding toString
in Customer
. You didn't post your version of Customer
, but that might look like
public class Customer
private String firstName;
private String lastName;
private String email;
public Customer(String first, String last, String email)
this.firstName = first.trim();
this.lastName = last.trim();
this.email = email.trim();
@Override
public String toString()
return String.format("first: %s, last: %s, email: %s", firstName, lastName, email);
Then you might use String.split
and Arrays.stream
and map your entries to Customer
instances like
String csv = " jimmy ,johnson,jjohnson@gmail.com", "Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org" ;
List<Customer> customs = Arrays.stream(csv).map(s -> s.split("\s*,\s*"))
.map(t -> new Customer(t[0], t[1], t[2])).collect(Collectors.toList());
for (Customer c : customs)
System.out.println(c);
And I get
first: jimmy, last: johnson, email: jjohnson@gmail.com
first: Joe, last: Donald, email: Joe_Donald@donald.org
first: ARTHUR, last: THOMPSON, email: ARTHUR@thompson.org
answered Nov 12 at 20:51
Elliott Frisch
152k1389178
152k1389178
add a comment |
add a comment |
Here's a suggestion for you, a couple of things to point out:
- I'm using a List instead of an array, a list can grow dynamically
and you don't need to specify the size up front, it's also a bit
easier to work with than an array. - Use a foreach loop instead of standard for, you don't need the index
so a foreach is perfect - When splitting the line, just check you get the expected number of
parts, perhaps treat the others as errors, so safeguard yourself
later when you expect to find certain things in certain spots. - The trim lets you get rid of whitespace, it's always good to clean
the data as soon as you can so you don't get junk filtering through
your application. - Consider using Lombok, it gives you nice annotations to generate
accessor methods, toString etc
sample code:
public static void main(String args) throws IOException
String csv =
" jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org"
;
// use a List rather than array, so it can grow dynamically
List<Customer> customers = new ArrayList<Customer>();
for (String line : csv)
System.out.println("Processing line: " + line);
String parts = line.split(",");
if (parts.length != 3)
System.out.println("Expected to find 3 parts in the line, but got " + parts.length);
// construct the customer, notice the .trim() to remove any whitespace
Customer customer = new Customer(parts[0].trim(), parts[1].trim(), parts[2].trim());
customers.add(customer);
System.out.println("Printing out customer list:");
// loop through the customers and print them out
for (Customer c : customers)
System.out.println("firstName: " + c.firstName);
System.out.println("lastName: " + c.lastName);
System.out.println("email: " + c.email);
System.out.println("n");
static class Customer
// accessors removed, consider using Lombok for @Data, @Getter, @Setter etc
String firstName;
String lastName;
String email;
public Customer(String firstName, String lastName, String email)
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
This is the output I get, which I believe is what you're looking for
Processing line: jimmy ,johnson,jjohnson@gmail.com
Processing line: Joe,Donald,Joe_Donald@donald.org
Processing line: ARTHUR,THOMPSON,ARTHUR@thompson.org
Printing out customer list:
firstName: jimmy
lastName: johnson
email: jjohnson@gmail.com
firstName: Joe
lastName: Donald
email: Joe_Donald@donald.org
firstName: ARTHUR
lastName: THOMPSON
email: ARTHUR@thompson.org
Good luck!
add a comment |
Here's a suggestion for you, a couple of things to point out:
- I'm using a List instead of an array, a list can grow dynamically
and you don't need to specify the size up front, it's also a bit
easier to work with than an array. - Use a foreach loop instead of standard for, you don't need the index
so a foreach is perfect - When splitting the line, just check you get the expected number of
parts, perhaps treat the others as errors, so safeguard yourself
later when you expect to find certain things in certain spots. - The trim lets you get rid of whitespace, it's always good to clean
the data as soon as you can so you don't get junk filtering through
your application. - Consider using Lombok, it gives you nice annotations to generate
accessor methods, toString etc
sample code:
public static void main(String args) throws IOException
String csv =
" jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org"
;
// use a List rather than array, so it can grow dynamically
List<Customer> customers = new ArrayList<Customer>();
for (String line : csv)
System.out.println("Processing line: " + line);
String parts = line.split(",");
if (parts.length != 3)
System.out.println("Expected to find 3 parts in the line, but got " + parts.length);
// construct the customer, notice the .trim() to remove any whitespace
Customer customer = new Customer(parts[0].trim(), parts[1].trim(), parts[2].trim());
customers.add(customer);
System.out.println("Printing out customer list:");
// loop through the customers and print them out
for (Customer c : customers)
System.out.println("firstName: " + c.firstName);
System.out.println("lastName: " + c.lastName);
System.out.println("email: " + c.email);
System.out.println("n");
static class Customer
// accessors removed, consider using Lombok for @Data, @Getter, @Setter etc
String firstName;
String lastName;
String email;
public Customer(String firstName, String lastName, String email)
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
This is the output I get, which I believe is what you're looking for
Processing line: jimmy ,johnson,jjohnson@gmail.com
Processing line: Joe,Donald,Joe_Donald@donald.org
Processing line: ARTHUR,THOMPSON,ARTHUR@thompson.org
Printing out customer list:
firstName: jimmy
lastName: johnson
email: jjohnson@gmail.com
firstName: Joe
lastName: Donald
email: Joe_Donald@donald.org
firstName: ARTHUR
lastName: THOMPSON
email: ARTHUR@thompson.org
Good luck!
add a comment |
Here's a suggestion for you, a couple of things to point out:
- I'm using a List instead of an array, a list can grow dynamically
and you don't need to specify the size up front, it's also a bit
easier to work with than an array. - Use a foreach loop instead of standard for, you don't need the index
so a foreach is perfect - When splitting the line, just check you get the expected number of
parts, perhaps treat the others as errors, so safeguard yourself
later when you expect to find certain things in certain spots. - The trim lets you get rid of whitespace, it's always good to clean
the data as soon as you can so you don't get junk filtering through
your application. - Consider using Lombok, it gives you nice annotations to generate
accessor methods, toString etc
sample code:
public static void main(String args) throws IOException
String csv =
" jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org"
;
// use a List rather than array, so it can grow dynamically
List<Customer> customers = new ArrayList<Customer>();
for (String line : csv)
System.out.println("Processing line: " + line);
String parts = line.split(",");
if (parts.length != 3)
System.out.println("Expected to find 3 parts in the line, but got " + parts.length);
// construct the customer, notice the .trim() to remove any whitespace
Customer customer = new Customer(parts[0].trim(), parts[1].trim(), parts[2].trim());
customers.add(customer);
System.out.println("Printing out customer list:");
// loop through the customers and print them out
for (Customer c : customers)
System.out.println("firstName: " + c.firstName);
System.out.println("lastName: " + c.lastName);
System.out.println("email: " + c.email);
System.out.println("n");
static class Customer
// accessors removed, consider using Lombok for @Data, @Getter, @Setter etc
String firstName;
String lastName;
String email;
public Customer(String firstName, String lastName, String email)
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
This is the output I get, which I believe is what you're looking for
Processing line: jimmy ,johnson,jjohnson@gmail.com
Processing line: Joe,Donald,Joe_Donald@donald.org
Processing line: ARTHUR,THOMPSON,ARTHUR@thompson.org
Printing out customer list:
firstName: jimmy
lastName: johnson
email: jjohnson@gmail.com
firstName: Joe
lastName: Donald
email: Joe_Donald@donald.org
firstName: ARTHUR
lastName: THOMPSON
email: ARTHUR@thompson.org
Good luck!
Here's a suggestion for you, a couple of things to point out:
- I'm using a List instead of an array, a list can grow dynamically
and you don't need to specify the size up front, it's also a bit
easier to work with than an array. - Use a foreach loop instead of standard for, you don't need the index
so a foreach is perfect - When splitting the line, just check you get the expected number of
parts, perhaps treat the others as errors, so safeguard yourself
later when you expect to find certain things in certain spots. - The trim lets you get rid of whitespace, it's always good to clean
the data as soon as you can so you don't get junk filtering through
your application. - Consider using Lombok, it gives you nice annotations to generate
accessor methods, toString etc
sample code:
public static void main(String args) throws IOException
String csv =
" jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org"
;
// use a List rather than array, so it can grow dynamically
List<Customer> customers = new ArrayList<Customer>();
for (String line : csv)
System.out.println("Processing line: " + line);
String parts = line.split(",");
if (parts.length != 3)
System.out.println("Expected to find 3 parts in the line, but got " + parts.length);
// construct the customer, notice the .trim() to remove any whitespace
Customer customer = new Customer(parts[0].trim(), parts[1].trim(), parts[2].trim());
customers.add(customer);
System.out.println("Printing out customer list:");
// loop through the customers and print them out
for (Customer c : customers)
System.out.println("firstName: " + c.firstName);
System.out.println("lastName: " + c.lastName);
System.out.println("email: " + c.email);
System.out.println("n");
static class Customer
// accessors removed, consider using Lombok for @Data, @Getter, @Setter etc
String firstName;
String lastName;
String email;
public Customer(String firstName, String lastName, String email)
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
This is the output I get, which I believe is what you're looking for
Processing line: jimmy ,johnson,jjohnson@gmail.com
Processing line: Joe,Donald,Joe_Donald@donald.org
Processing line: ARTHUR,THOMPSON,ARTHUR@thompson.org
Printing out customer list:
firstName: jimmy
lastName: johnson
email: jjohnson@gmail.com
firstName: Joe
lastName: Donald
email: Joe_Donald@donald.org
firstName: ARTHUR
lastName: THOMPSON
email: ARTHUR@thompson.org
Good luck!
answered Nov 12 at 20:58
Jimmy
8,01135115200
8,01135115200
add a comment |
add a comment |
I think your best bet here is to treat each element of your csv array as a distinct customer. There's no need to concatenate them all into one big string.
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int cidx = 0; cidx < csv.length; cidx++)
String fields = csv[cidx].split(",");
customs[cidx++] = new Customer(
fields.length>0 ? fields[0].trim() : null,
fields.length>1? fields[1].trim() : null,
fields.length>2? fields[2].trim() : null);
for (Customer custom : customs)
System.out.println("first="+custom.getFirst_name() + ", last="+custom.getLast_name()+", email="+custom.getEmail());
add a comment |
I think your best bet here is to treat each element of your csv array as a distinct customer. There's no need to concatenate them all into one big string.
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int cidx = 0; cidx < csv.length; cidx++)
String fields = csv[cidx].split(",");
customs[cidx++] = new Customer(
fields.length>0 ? fields[0].trim() : null,
fields.length>1? fields[1].trim() : null,
fields.length>2? fields[2].trim() : null);
for (Customer custom : customs)
System.out.println("first="+custom.getFirst_name() + ", last="+custom.getLast_name()+", email="+custom.getEmail());
add a comment |
I think your best bet here is to treat each element of your csv array as a distinct customer. There's no need to concatenate them all into one big string.
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int cidx = 0; cidx < csv.length; cidx++)
String fields = csv[cidx].split(",");
customs[cidx++] = new Customer(
fields.length>0 ? fields[0].trim() : null,
fields.length>1? fields[1].trim() : null,
fields.length>2? fields[2].trim() : null);
for (Customer custom : customs)
System.out.println("first="+custom.getFirst_name() + ", last="+custom.getLast_name()+", email="+custom.getEmail());
I think your best bet here is to treat each element of your csv array as a distinct customer. There's no need to concatenate them all into one big string.
String csv = " jimmy ,johnson,jjohnson@gmail.com",
"Joe,Donald,Joe_Donald@donald.org",
"ARTHUR,THOMPSON,ARTHUR@thompson.org";
Customer customs = new Customer[csv.length];
for (int cidx = 0; cidx < csv.length; cidx++)
String fields = csv[cidx].split(",");
customs[cidx++] = new Customer(
fields.length>0 ? fields[0].trim() : null,
fields.length>1? fields[1].trim() : null,
fields.length>2? fields[2].trim() : null);
for (Customer custom : customs)
System.out.println("first="+custom.getFirst_name() + ", last="+custom.getLast_name()+", email="+custom.getEmail());
answered Nov 12 at 20:59
Tom Drake
42737
42737
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53269689%2fconvert-string-array-with-3-pieces-of-information-into-an-array-of-objects-jav%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown