实体

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文件的更多相关文章

  1. Android开发——自动生成Android屏幕适配的dimens.xml文件

    使用dimens.xml解决屏幕适配问题是Android官方解决方案,本文主要讲述了如何自动生成Android屏幕适配的dimens.xml,减少了工作量,在维护dimens.xml文件时更加省时省力 ...

  2. 如何在IJ中使用Jaxb2通过xml定义生成对应的Java Entity类的文件

    #0. 准备要转换的xml文件,在Project视界中,右击这个xml文件,在弹出的菜单上选择“Generate XSD schema from XML File...”, 按默认设置生成xsd文件. ...

  3. netbeans生成的maven工程没有web.xml文件 如何新建

    使用netbeans生成的maven工程没有web.xml 需要自己新建 步骤: 下一步,完成

  4. Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件

    原文:转:Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件 2011-04-30 12:50 很多人不知道怎么用 IntelliJ IDE ...

  5. 生成 hibernate 映射文件和实体类

    创建web工程,使用Hibernate的时候,在工程里一个一个创建实体类太麻烦,浪费时间,现在教大家如何用MyEclipse自动生成Hibernate映射文件及实体类 方法/步骤   创建数据库,创建 ...

  6. Mybatis Generator生成Mybatis Dao接口层*Mapper.xml以及对应实体类

    [前言] 使用Mybatis-Generator自动生成Dao.Model.Mapping相关文件,Mybatis-Generator的作用就是充当了一个代码生成器的角色,使用代码生成器不仅可以简化我 ...

  7. XML文件与实体类的互相转换

    XML文件与实体类的互相转换 一.将XML文件反序列化为实体类对象 1. 通常程序的配置信息都保存在程序或者网站的专门的配置文件中(App.config/web.config).但是现在为了演示XML ...

  8. T4 模板自动生成带注释的实体类文件

    T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll 生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 如果你没有 ...

  9. Intellij IDEA 通过数据库表逆向生成带注释的实体类文件超级详细步骤,附详细解决方案

    参考:https://blog.csdn.net/qq_34371461/article/details/80571281  https://blog.csdn.net/mqchenrong/arti ...

随机推荐

  1. 利用OPENSSL 实现MD5加密。

    #include <stdio.h> #include "openssl/evp.h" #include "openssl/md5.h" #incl ...

  2. Oracle 中记录用户登录信息

    我们可以使用 Oracle Audit 函数来记录用户登录信息,但是如果开放了 Audit 函数将会使 Oracle 性能下降,甚至导致 Oracle 崩溃.那我们如何才能记录用户登录信息呢?其实我们 ...

  3. The message queue

    今晚来整理一下消息队列,消息队列是一条由消息连接而成的链表,存在内核里面,通过消息对了的引用标识符来访问,每个消息队列都有一个msqid_ds结构与之对应,这个结构保存了消息队列的当前状态参数,这个结 ...

  4. Angular2 从0到1 (一)

    史上最简单Angular2教程,大叔都学会了 作者:王芃 wpcfan@gmail.com 第一节:Angular 2.0 从0到1 (一)第二节:Angular 2.0 从0到1 (二)第三节:An ...

  5. 如何更好的理解(pageX,pageY,clientX,clientY,eventX,eventY,scrollX,scrollY,screenX,screenY,event.offsetX,event.offsetY,offsetLeft,style.left)

    1 pageX,pageY:鼠标指针相对于当前窗口的X,Y坐标,计算区域包括窗口自身的控件和滚动条.(火狐特有) 2 event.clientX,event.clientY:鼠标指针相对于当前窗口的X ...

  6. ZooKeeper(3.4.5) - 开源客户端 Curator(2.7.0) 的简单示例

    一.创建会话 1. 创建会话 package com.huey.dream.demo; import org.apache.curator.framework.CuratorFramework; im ...

  7. Unity Rigidbody 刚体中的Angular Drag和Freeze Position/Rotation

    Rigidbody中 Angular Drag  (角阻力):同样指的是空气阻力,只不过是用来阻碍物体旋转的.如果设置成无限的话,物体会立即停止旋转.如果设置成0,物体在上升过程中,会发生侧翻旋转. ...

  8. Android开发—— Native 与 Web 之架构抉择

    前 言 移动App是对URL和搜索引擎的革命,当今移动App开发貌似出现两大阵营:Native 和 Web,各自都认为自己才是未来的趋势,Native操作流畅.迅速,Web开发周期相对较短,还能轻松跨 ...

  9. 利用ExpandableListView和gridview 显示可展开折叠菜单导航

    这篇随身笔带来的是结合聚合数据“菜谱大全”做的一个菜谱可折叠一级+二级列表. 先发来一些截图一睹为快吧. ExpandableListView 可用于折叠型菜单列表,其布局主要通过getGroupVi ...

  10. SQL Server的三种物理连接之Merge join(二)

    简介 merge join 对两个表在连接列上按照相同的规则排序,然后再做merge,匹配的输出. 下面这个动态图展示了merge join的详细过程. merge join示例 创建两个表 IF O ...