生成XML文件,通过实体生成XML文件
实体
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml.Serialization;//引入空间
namespace Gome.OpenJob.Model
{
/// <summary>
/// 全量索引文件
/// 作者:赵亮
/// 创建时间:2014、04、08
/// </summary>
[XmlRoot("root")]
public class XMLBaiDuFullEntitys
{
/// <summary>
/// feed数据格式的版本号
/// </summary>
[XmlElement("version")]
public string version { get; set; }//没有库里
/// <summary>
/// feed数据文件最近修改时间
/// </summary>
[XmlElement("modified")]
public string modifiedDate { get; set; }
/// <summary>
/// 结合商家创建的百度推广平台账号
/// </summary>
[XmlElement("seller_id")]
public string seller_Name { get; set; }
/// <summary>
/// 商家全量推送过来的所有商品数量
/// </summary>
[XmlElement("total")]
public string totalnumber { get; set; }
/// <summary>
/// 商家数据包所在的目录地址
/// </summary>
[XmlElement("dir")]
public string dirItem { get; set; }
/// <summary>
/// 全量更新只允许 upload 上架商品,此处一个 outer_id 将对应 1000 个商品
/// </summary>
[XmlElement("item_ids")]
public ItemIds ItemIds { get; set; }
}
/// <summary>
/// 全量更新只允许 upload 上架商品,此处一个 outer_id 将对应 1000 个商品
/// </summary>
public class ItemIds
{
[XmlElement("outer_id")]
public List<OutId> outIds { get; set; }
}
public class OutId
{
[XmlAttribute("action")]
public string Action { get; set; }
[XmlText]
public string OutText { get; set; }
}
}
************************************
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Gome.OpenJob.Model;
using System.IO;
using System.Xml.Serialization;
using System.Xml;
using System.Configuration;
namespace Gome.OpenJob.Common
{
/// <summary>
/// 生成全量
/// </summary>
public sealed class GenerateXML
{
private static XMLBaiDuFullEntitys m_humanResource = null;
/// <summary>
/// 用于生成详细内容
/// </summary>
private static XMLBaiDuGoodsDetailTest m_GoodsDetailTestResource = null;
private GenerateXML() { }
public static XMLBaiDuFullEntitys Get(string path)
{
if (m_humanResource == null)
{
FileStream fs = null;
try
{
XmlSerializer xs = new XmlSerializer(typeof(XMLBaiDuFullEntitys));
fs = new FileStream(path, FileMode.Open, FileAccess.Read);
m_humanResource = (XMLBaiDuFullEntitys)xs.Deserialize(fs);
fs.Close();
return m_humanResource;
}
catch
{
if (fs != null)
fs.Close();
throw new Exception("Xml deserialization failed!");
}
}
else
{
return m_humanResource;
}
}
//生成全量索引
public static void Set(string path, XMLBaiDuFullEntitys humanResource)
{
if (humanResource == null)
throw new Exception("Parameter humanResource is null!");
FileStream fs = null;
try
{
XmlSerializer xs = new XmlSerializer(typeof(XMLBaiDuFullEntitys));
string path_file = SystemConfig.GetValue("pathFiles");//Open.config
//生成文件的路径
string strPath = path_file + "\\" + path;
fs = new FileStream(strPath, FileMode.Create, FileAccess.Write);
xs.Serialize(fs, humanResource);
m_humanResource = null;
fs.Close();
}
catch
{
if (fs != null)
fs.Close();
throw new Exception("Xml serialization failed!");
}
}
}
}
***************************
/// <summary>
/// 生成全量索引文件
/// 作者:赵亮
/// 创建时间:2014、04、08
/// </summary>
/// <returns></returns>
public static int Notation = 0;
public XMLBaiDuFullEntitys FullAmount()
{
XMLBaiDuFullEntitys fu = new XMLBaiDuFullEntitys();
ItemIds ids = new ItemIds();
ids.outIds = new List<OutId>();
fu.ItemIds = ids;
string sqlnum = "select distinct count(*) from VIEW_CPS v inner join gome_category r on (v.category_id=r.categoryid) where seq=0 and v.state='已上架' and v.list_price is not null and v.list_price !=0";
DbCommand command = this.GetSqlStringCommand(sqlnum);
object num = this.ExecuteScalar(command);
int countnum = int.Parse(num.ToString()) + 1000 - 1;
string count = Math.Ceiling((double)countnum / (double)1000).ToString();
Notation = int.Parse(count);
//实体里传值
fu.version = "1.0";
fu.modifiedDate = DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss");
fu.seller_Name = "国美在线";
fu.totalnumber = num.ToString();//商品数量
fu.dirItem = "www.gome.com.cn";
//int outer_idNum = aa / 1000;
for (int i = 1; i <= int.Parse(count) - 2; i++)
{
OutId outId = new OutId();
outId.Action = "upload";
outId.OutText = i.ToString();
fu.ItemIds.outIds.Add(outId);
}
return fu;
}
***************************
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
BaiDuMicroPurchaseBLL abc = new BaiDuMicroPurchaseBLL();
abc.baiduFullAmount();
XMLBaiDuFullEntitys xmlList = abc.baiduFullAmount();
//全量索引文件名
string path = SystemConfig.GetValue("FullIndexName");//Open.config
//调用生成xml文件
GenerateXML.Set(path, xmlList);
abc.baiduCommodityInformationFile();
Console.Read();
}
}
}
生成XML文件,通过实体生成XML文件的更多相关文章
- Android开发——自动生成Android屏幕适配的dimens.xml文件
使用dimens.xml解决屏幕适配问题是Android官方解决方案,本文主要讲述了如何自动生成Android屏幕适配的dimens.xml,减少了工作量,在维护dimens.xml文件时更加省时省力 ...
- 如何在IJ中使用Jaxb2通过xml定义生成对应的Java Entity类的文件
#0. 准备要转换的xml文件,在Project视界中,右击这个xml文件,在弹出的菜单上选择“Generate XSD schema from XML File...”, 按默认设置生成xsd文件. ...
- netbeans生成的maven工程没有web.xml文件 如何新建
使用netbeans生成的maven工程没有web.xml 需要自己新建 步骤: 下一步,完成
- Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件
原文:转:Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件 2011-04-30 12:50 很多人不知道怎么用 IntelliJ IDE ...
- 生成 hibernate 映射文件和实体类
创建web工程,使用Hibernate的时候,在工程里一个一个创建实体类太麻烦,浪费时间,现在教大家如何用MyEclipse自动生成Hibernate映射文件及实体类 方法/步骤 创建数据库,创建 ...
- Mybatis Generator生成Mybatis Dao接口层*Mapper.xml以及对应实体类
[前言] 使用Mybatis-Generator自动生成Dao.Model.Mapping相关文件,Mybatis-Generator的作用就是充当了一个代码生成器的角色,使用代码生成器不仅可以简化我 ...
- XML文件与实体类的互相转换
XML文件与实体类的互相转换 一.将XML文件反序列化为实体类对象 1. 通常程序的配置信息都保存在程序或者网站的专门的配置文件中(App.config/web.config).但是现在为了演示XML ...
- T4 模板自动生成带注释的实体类文件
T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll 生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 如果你没有 ...
- Intellij IDEA 通过数据库表逆向生成带注释的实体类文件超级详细步骤,附详细解决方案
参考:https://blog.csdn.net/qq_34371461/article/details/80571281 https://blog.csdn.net/mqchenrong/arti ...
随机推荐
- Storm中并发程度的理解
Storm中涉及到了很多组件,例如nimbus,supervisor等等,在参考了这两篇文章之后,对这个有了更好的理解. Understanding the parallelism of a Stor ...
- [转]Oracle hang分析
hanganalyze是ORACLE的一款性能诊断工具,这个款工具是从oracle 8.0.6开始可用,在oracle数据库出现严重的性能问题的时候它可以帮助你定位问题所在. 1.首先说说hangan ...
- Log4Net(二)之记录日志到文档详解
原创文章,转载必需注明出处:http://www.ncloud.hk/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/log4net-%E4%BA%8C-%E4%B9%8B% ...
- Apache服务器中配置虚拟机的方法
新浪微博虚拟机开发配置步骤及介绍.1.由于后面虚拟机中需要用到Rewrite所以先编辑Apache的conf目录下的httpd.conf文件.(可根据实际需要操作)添加mod_rewrite.so模块 ...
- 命名管道FIFO
首先我得检讨一下自己,这几天有些颓呀,打不起精神,板子出了点问题,果真自学还是很困难呀,硬件方面难解决呀,理想与现实还是很有差距的,伤透了,凌乱了. 一直在理解进程间通信的问题.发现上次忽略了一个问题 ...
- Commons Math - Primes
org.apache.commons.math3.primes.Primes 是关于质数操作的工具类. 1. public static boolean isPrime(int n) 判断 n 是否为 ...
- Spring(3.2.3) - Beans(2): 属性注入 & 构造注入
依赖注入是指程序运行过程中们如果需要另外的对象协作(访问它的属性或调用它的方法)时,无须在代码中创建被调用者,而是依赖于外部容器的注入. 属性注入(Setter Injection) 属性注入是指 I ...
- C#操作Excel数据增删改查示例
Excel数据增删改查我们可以使用c#进行操作,首先创建ExcelDB.xlsx文件,并添加两张工作表,接下按照下面的操作步骤即可 C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文 ...
- python学习day4--python基础--字典
字典的常用操作: #字典天然去重,key唯一,如果key相同,只能打印出一个 id_db={ 220456789852963741:{ 'name':"alex", 'age':3 ...
- jquery之音乐均衡器
制作这个音乐均衡器需要一个equalizer插件(插件我已经上传),下面介绍一下网页的BGM的相关属性: hidden="true"表示隐藏播放,即不显示播放器的外观,若要想显示, ...