我有一些经度\纬度坐标聚集在一个字符串中,我想分成经度\纬度对。感谢stackoverflow,我已经能够想出一些将它拆分成多维字符串数组的linq。有没有办法将字符串直接拆分为接受经度纬度与字符串数组的对象然后创建对象?
string segment = "51.54398, -0.27585;51.55175, -0.29631;51.56233, -0.30369;51.57035, -0.30856;51.58157, -0.31672;51.59233, -0.3354"
string[][] array = segment.Split(';').Select(s => s.Split(',')).ToArray();
foreach (string[] pair in array)
{
//create object here
}
答案 0 :(得分:23)
你很亲密。这样的事情可能会有所帮助:
var pairSequence = segment.Split(';')
.Select(s => s.Split(','))
.Select(a => new { Lat = double.Parse(a[0]), Long = double.Parse(a[1]) });
答案 1 :(得分:6)
假设您有一个Coordinate
类,其中包含public Coordinate(double x, double y)
构造函数,您可以这样做:
Coordinate[] result = segment
.Split(';')
.Select(s => s.Split(','))
.Select(a => new Coordinate(x: double.Parse(a[0], NumberStyles.Number),
y: double.Parse(a[1], NumberStyles.Number))
.ToArray();
或同样
var query = from item in segment.Split(';')
let parts = item.Split(',')
let x = double.Parse(parts[0], NumberStyles.Number)
let y = double.Parse(parts[1], NumberStyles.Number)
select new Coordinate(x, y);
Coordinate[] result = query.ToArray();
答案 2 :(得分:3)
你可以这样做:
public class GeoCoordinates {
public decimal Latitude { get; set; }
public decimal Longitude { get; set; }
public GeoCoordinates( string latLongPair ) {
decimal lat, lng;
var parts = latLongPair.Split( new[] { ',' } );
if( decimal.TryParse( parts[0], out lat ) &&
decimal.TryParse( parts[1], out lng ) ) {
Latitude = lat;
Longitude = lng;
} else {
// you could set some kind of "ParseFailed" or "Invalid" property here
}
}
}
然后你就可以创建一个GeoCoordinate类的集合:
var coords = segment.Split( new[] {';'} ).Select( x => new GeoCoordinates( x ) );
答案 3 :(得分:3)
这是一个'有点'不错的片段,显示:
您希望在现实生活中提取某些代码(例如数字解析)。
查看 live on Ideone.com 。
using System;
using System.Linq;
using System.Text.RegularExpressions;
using System.Globalization;
namespace SODemo
{
class MainClass
{
private static readonly CultureInfo CInfo = CultureInfo.CreateSpecificCulture("en-US");
public static void Main (string[] args)
{
string segment = "51.54398, -0.27585;51.55175, -0.29631;51.56233, -0.30369;51.57035, -0.30856;51.58157, -0.31672;51.59233, -0.3354";
var re = new Regex(@"\s*(?<lat>[-+]?[0-9.]+),\s*(?<lon>[-+]?[0-9.]+)\s*;", RegexOptions.Compiled | RegexOptions.CultureInvariant | RegexOptions.IgnoreCase);
var locations = re.Matches(segment).Cast<Match>().Select(m => new
{
Lat = decimal.Parse(m.Groups["lat"].Value, CInfo),
Long = decimal.Parse(m.Groups["lon"].Value, CInfo),
});
foreach (var l in locations)
Console.WriteLine(l);
}
}
}
输出:
{ Lat = 51,54398, Long = -0,27585 }
{ Lat = 51,55175, Long = -0,29631 }
{ Lat = 51,56233, Long = -0,30369 }
{ Lat = 51,57035, Long = -0,30856 }
{ Lat = 51,58157, Long = -0,31672 }
答案 4 :(得分:2)
您是否有必要使用LINQ?您可以使用标准字符串拆分功能完成所有操作:
string[] pairsOfCoords = segment.Split(';');
List<CoordsObject> listOfCoords = new List<CoordsObject>();
foreach (string str in pairsOfCoords)
{
string[] coords = str.Split(',');
CoordsObject obj = new CoordsObject(coords[0], coords[1]);
listOfCoords.Add(obj);
}
答案 5 :(得分:1)
我可能会多补充一点。感谢dtb的开始,upvoted。如果你破坏了解析功能,你可以更干净地处理错误条件,例如数组中错误的元素数,或者不解析为小数的东西。
Coordinate[] result = segment
.Split(';')
.Select(s => s.Split(','))
.Select(BuildCoordinate)
.ToArray();
Coordrinate BuildCoordinate(string[] coords)
{
if(coords.Length != 2)
return null;
return new Coordinate(double.Parse(a[0].Trim(), double.Parse(a[1]);
}
答案 6 :(得分:0)
有些任务更容易解决旧方法:
var split = segment.Split();
var coordinates = new List<Coordinate>(split.Length);
foreach(string s in split)
{
coordinates.Add(new Coordinate(s));
}