C# VB 数组转DataTable的回复https://bbs.csdn.net/topics/392560517

也就几句代码完成的事。使用LINQ就一句话的事。

        private class 佛诞
        { 
            public string 名称 { get; set; } 
            public int 日期 { get; set; }
            public 佛诞(string 称号, int 诞日)
            { 名称 = 称号; 日期 = 诞日; }
        }
        佛诞[] 佛诞组 = new 佛诞[] { new 佛诞("那摩阿弥陀佛!圣诞", 1117), new 佛诞("那摩地藏王菩萨!圣诞", 729), new 佛诞("那摩地藏王菩萨!圣诞", 730)
            , new 佛诞("那摩释迦牟尼佛!圣诞", 48), new 佛诞("那摩释迦牟尼佛!出家", 28), new 佛诞("那摩释迦牟尼佛!成道", 128), new 佛诞("那摩释迦牟尼佛!涅槃", 215)
            , new 佛诞("那摩观世音菩萨!圣诞", 219), new 佛诞("那摩观世音菩萨!出家", 919), new 佛诞("那摩观世音菩萨!成道", 619), new 佛诞("那摩大势至菩萨!圣诞", 713)
        , new 佛诞("那摩普贤菩萨!圣诞", 221), new 佛诞("那摩文殊师利菩萨!圣诞", 44), new 佛诞("那摩禅宗达摩祖师!圣诞", 105), new 佛诞("那摩慧能禅宗六祖!圣诞", 29), new 佛诞("那摩慧能禅宗六祖!圆寂", 83)
        , new 佛诞("那摩华严菩萨!圣诞", 1229), new 佛诞("那摩药师佛!圣诞", 930), new 佛诞("那摩燃灯古佛!圣诞", 822), new 佛诞("那摩定光佛!圣诞", 16), new 佛诞("那摩弥勒菩萨!圣诞;春节", 11)
        , new 佛诞("那摩福德土地正神!圣诞", 22), new 佛诞("那摩准提菩萨!圣诞", 316), new 佛诞("那摩药王菩萨!圣诞", 428), new 佛诞("那摩伽蓝菩萨!圣诞", 518)
        , new 佛诞("那摩韦驮菩萨!圣诞", 63), new 佛诞("那摩第五殿阎罗天子!圣诞", 18), new 佛诞("那摩帝释天尊!圣诞", 19), new 佛诞("那摩妈祖升仙!重阳节", 729)
        , new 佛诞("那摩妈祖!圣诞", 323), new 佛诞("那摩文昌帝君!圣诞", 23), new 佛诞("那摩第四殿五官王!圣诞", 218), new 佛诞("那摩第六殿卞城王!圣诞", 38)
        , new 佛诞("那摩中岳大帝;后土娘娘!圣诞", 319), new 佛诞("那摩子孙娘娘!圣诞", 320), new 佛诞("那摩第七殿泰山王!圣诞", 327), new 佛诞("那摩地藏王菩萨!圣诞", 729)
        , new 佛诞("佛欢喜日!盂兰盆节", 715), new 佛诞("元宵节!", 115), new 佛诞("端午节", 55), new 佛诞("七夕情人节", 77), new 佛诞("中秋节", 815), new 佛诞("中秋节", 815)
        , new 佛诞("腊八节", 128), new 佛诞("小年", 1223), new 佛诞("除夕", 1230), new 佛诞("道教中元节", 715)};

            DataTable 佛诞组表 = new DataTable("佛诞组");
            佛诞组表.Columns.Add("名称", typeof(string));
            佛诞组表.Columns.Add("日期", typeof(int));
            佛诞组.Select(aa => 佛诞组表.Rows.Add(new object[] { aa.名称, aa.日期 })).ToArray();

 

        void 请问如何查找多个符合条件的值() 
        {
            DataTable aa = new DataTable();
            foreach (string ss in "内码 简拼 品名 成份名 药品类别 规格 配伍禁忌".Split(' '))
                aa.Columns.Add(ss);
            var ff = "47019 RS 人参 人参 人参 支 藜芦;1111 LL 藜芦 藜芦 藜芦 g 人参,党参,玄参,西洋参,细辛;33212 XX 细辛 细辛 细辛 g 藜芦;2222 RS 蚺蛇 蚺蛇 蚺蛇 g 全蝎"
                .Split(';').Select(dd => dd.Split(' ')).ToArray();
            ff.Select(dd => aa.Rows.Add(dd)).ToArray();
            foreach (DataRow kk in aa.Rows)
                电话.Text += string.Join("", kk.ItemArray).Contains(姓名.Text) ?
                    string.Join(" ", kk.ItemArray) : "\r\n";
            MessageBox.Show(电话.Text);
        }

 

Public Class Form1

    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        Dim aa = New DataTable
        For Each ss In "内码 简拼 品名 成份名 药品类别 规格 配伍禁忌".Split(" ")
            aa.Columns.Add(ss)
        Next ss
        For Each ss In "47019 RS 人参 人参 人参 支 藜芦;1111 LL 藜芦 藜芦 藜芦 g 人参,党参,玄参,西洋参,细辛;33212 XX 细辛 细辛 细辛 g 藜芦;2222 RS 蚺蛇 蚺蛇 蚺蛇 g 全蝎".Split(";")
            aa.Rows.Add(ss.Split(" "))
        Next ss
        Dim ts = ""
        Dim dd As DataRow
        For Each dd In aa.Rows
            If String.Join(" ", dd.ItemArray).Contains("RS") Then
                ts += String.Join(" ", dd.ItemArray) + Chr(13) + Chr(10)
            End If
        Next dd
        MessageBox.Show(ts)
    End Sub

End Class

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个比较复杂的爬虫,需要使用Scrapy和Selenium进行结合,具体步骤如下: 1. 首先需要安装Scrapy和Selenium,可以使用pip安装,命令如下: ``` pip install scrapy pip install selenium ``` 2. 创建一个Scrapy项目,可以使用命令行工具`scrapy startproject <project_name>`来创建,这里假设项目名为`stock_data`。 ``` scrapy startproject stock_data ``` 3. 在`stock_data`目录下创建一个`spiders`文件夹,并在该文件夹下创建一个名为`stock_spider.py`的爬虫文件。 4. 在`stock_spider.py`中定义一个`StockSpider`类,该类继承自`scrapy.Spider`,并定义以下属性: ```python class StockSpider(scrapy.Spider): name = "stock" allowed_domains = ["vip.stock.finance.sina.com.cn"] start_urls = ["https://vip.stock.finance.sina.com.cn/mkt/#sh_a"] custom_settings = { "DOWNLOAD_DELAY": 2, "CONCURRENT_REQUESTS_PER_DOMAIN": 1, "CONCURRENT_REQUESTS_PER_IP": 1, "DOWNLOADER_MIDDLEWARES": { "stock_data.middlewares.SeleniumMiddleware": 100, }, "FEED_FORMAT": "csv", "FEED_URI": "stock_data.csv", } ``` - `name`:爬虫名称。 - `allowed_domains`:允许爬取的域名。 - `start_urls`:起始URL。 - `custom_settings`:自定义设置,包括下载延迟、并发请求数、下载器中间件、输出格式和输出路径等。 5. 在`stock_spider.py`中实现`parse`方法,该方法用于解析网页内容并提取数据。 ```python def parse(self, response): for tr in response.xpath('//table[@id="dataTable"]/tbody/tr'): item = {} item["code"] = tr.xpath("td[1]/a/text()").get() item["name"] = tr.xpath("td[2]/a/text()").get() item["last_price"] = tr.xpath("td[3]/span/text()").get() item["buy"] = tr.xpath("td[4]/span/text()").get() item["sell"] = tr.xpath("td[5]/span/text()").get() item["prev_close"] = tr.xpath("td[6]/span/text()").get() item["today_open"] = tr.xpath("td[7]/span/text()").get() item["today_high"] = tr.xpath("td[8]/span/text()").get() item["today_low"] = tr.xpath("td[9]/span/text()").get() item["volume"] = tr.xpath("td[10]/span/text()").get() item["turnover"] = tr.xpath("td[11]/span/text()").get() item["amplitude"] = tr.xpath("td[12]/span/text()").get() item["turnover_rate"] = tr.xpath("td[13]/span/text()").get() item["pb_ratio"] = tr.xpath("td[14]/span/text()").get() item["pe_ratio"] = tr.xpath("td[15]/span/text()").get() item["total_shares"] = tr.xpath("td[16]/span/text()").get() item["circulating_shares"] = tr.xpath("td[17]/span/text()").get() yield item ``` 6. 在`stock_data`目录下创建一个`middlewares`文件夹,并在该文件夹下创建一个名为`selenium_middleware.py`的中间件文件。 7. 在`selenium_middleware.py`中定义一个`SeleniumMiddleware`类,该类继承自`scrapy.downloadermiddlewares.DownloaderMiddleware`,并实现以下方法: ```python class SeleniumMiddleware(object): def __init__(self, driver_path): self.driver_path = driver_path @classmethod def from_crawler(cls, crawler): return cls( driver_path=crawler.settings.get("SELENIUM_DRIVER_PATH") ) def process_request(self, request, spider): if "selenium" in request.meta: driver = webdriver.Chrome(executable_path=self.driver_path) driver.get(request.url) time.sleep(2) body = driver.page_source return HtmlResponse( driver.current_url, body=body, encoding="utf-8", request=request ) ``` - `__init__`方法:初始化方法,接收一个`driver_path`参数,表示ChromeDriver的路径。 - `from_crawler`类方法:从爬虫配置中获取`SELENIUM_DRIVER_PATH`参数,并传递给初始化方法。 - `process_request`方法:处理请求方法,如果请求的`meta`属性中包含`selenium`,则使用ChromeDriver访问该URL并返回`HtmlResponse`对象。 8. 在`settings.py`中添加以下配置: ```python SELENIUM_DRIVER_PATH = "chromedriver.exe" DOWNLOADER_MIDDLEWARES = { "stock_data.middlewares.SeleniumMiddleware": 100, } ``` - `SELENIUM_DRIVER_PATH`:ChromeDriver的路径。 - `DOWNLOADER_MIDDLEWARES`:下载器中间件,使用自定义的`selenium_middleware.SeleniumMiddleware`中间件。 9. 最后,在命令行中进入`stock_data`目录,执行以下命令启动爬虫: ``` scrapy crawl stock ``` 10. 爬虫会自动爬取网站中的数据,并将数据保存到`stock_data.csv`文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值