关于C#中linq TO xml 技术城市地区三级联动

WoKanBuDao 2016-05-26 09:11:44

RT分别是实现的结果和参照的xml文件
,现在是做到了得到市地名,遇到了问题。
// var city = from c in es.Elements("province").Attributes("name") select c; //得到省

var city = from c in es.Elements("province").Elements("city").Attributes("name") select c; //得到市

var shili = from ss in es.Elements("provice").Elements("city").Attributes("name") where ss.Parent.Value== comboBox1.Text select ss;

变量名为shili的是自己试验的数据,但是为空,想了好久,没有得出结果,求大神指教。。。。
我的想法是 var city = from c in es.Elements("province").Elements("city").Attributes("name") select c; //得到市 根据这行代码在里面添加where条件,但是条件要为c的上一级元素,因为是初学,不敢确定自己的想法否正确,所以前来提问。。。

我只有5分了。。。
...全文
326 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ysp 2016-05-31
  • 打赏
  • 举报
回复
获取省份: var ps = from p in doc.Elements("province").Attributes("name") select p; 获取城市: var cs = from c in doc.Elements("province").Elements("city").Attributes("name") where c.Parent.Parent.Attribute("name").Value == dropProvinceList.Text select c; 获取县区: var cs = from c in doc.Elements("province").Elements("city").Elements("country").Attributes("name") where c.Parent.Parent.Attribute("name").Value == dropCityList.Text && c.Parent.Parent.Parent.Attribute("name").Value == dropProvinceList.Text select c;
  • 打赏
  • 举报
回复
c不能是Attributes("name") ,这段要去掉,等判断完之后才取Attributes("name")
WoKanBuDao 2016-05-26
  • 打赏
  • 举报
回复
引用 2 楼 starfd 的回复:
c.Parent就可以拿到它的父级,然后Attribute什么的直接写就可以了
var shili = from ss in es.Elements("provice").Elements("city").Attributes("name") where ss.Parent.Attribute("name").Value==comboBox1.Text select ss; 这样写还是不行 ,。。
  • 打赏
  • 举报
回复
c.Parent就可以拿到它的父级,然后Attribute什么的直接写就可以了
WoKanBuDao 2016-05-26
  • 打赏
  • 举报
回复
把之前的未接帖子给结了。。。。才可以发出来
WoKanBuDao 2016-05-26
  • 打赏
  • 举报
回复
算了 这点先放放吧 可能是基础学的不好,以后再来看

8,497

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧