精华内容
下载资源
问答
  • C++文本文件按列排序,写回文本文件,遇到非法的数字放在文件最后不参与排序
  • C#,listView按列排序、listView数据快速载入
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Windows.Forms;
    
    namespace ListViewSpace
    {
        /// <summary>
        /// 对ListView点击列标题自动排序功能,快速载入大量数据至listView
        /// </summary>
        public class ListViewUpdate
        {
            / <summary>
            / 添加data至listView中进行显示
            / </summary>
            //public static void addToListView(ListView listView, List<String> data)
            //{
            //    if (data.Count > 0)
            //    {
            //        ListViewItem iteam = new ListViewItem(data.ToArray());
            //        listView.Items.Add(iteam);
            //    }
            //}
    
            /// <summary>
            /// 添加AllDatas至listView中进行显示
            /// </summary>
            public static void addToListView(ListView listView, List<List<String>> AllDatas)
            {
                // 移除原有数据
                listView.Items.Clear();
    
                // 生成listView数据
                List<ListViewItem> listIteams = new List<ListViewItem>();
                foreach (List<String> iteamData in AllDatas)
                {
                    ListViewItem iteam = new ListViewItem(iteamData.ToArray());
                    //iteam.ImageIndex = 0;	// 可指定ListViewItem图标索引
    
                    listIteams.Add(iteam);
                }
    
                // 添加至listView中进行显示(使用AddRange添加可实现快速载入)
                listView.Items.AddRange(listIteams.ToArray());
            }
    
            /// <summary>
            /// 添加AllDatas至listView中进行显示
            /// </summary>
            public static void addToListView(ListView listView, string[][] AllDatas)
            {
                // 移除原有数据
                listView.Items.Clear();
    
                // 生成listView数据
                List<ListViewItem> listIteams = new List<ListViewItem>();
                foreach (string[] iteamData in AllDatas)
                {
                    ListViewItem iteam = new ListViewItem(iteamData);
                    //iteam.ImageIndex = 0;
    
                    listIteams.Add(iteam);
                }
    
                // 添加至listView中进行显示(使用AddRange添加可实现快速载入)
                listView.Items.AddRange(listIteams.ToArray());
            }
        }
    
        /// <summary>
        /// 对ListView点击列标题自动排序功能
        /// 
        /// 示例: ListViewSort.AddColumnSort(listView1);          // 为listView1添加按列排序逻辑
        /// </summary>
        public class ListViewSort
        {
            /// <summary>
            /// 为listView添加列点击排序逻辑,可在FormLoad()事件中为指定的listView添加排序逻辑
            /// </summary>
            public static void AddColumnSort(ListView list)
            {
                list.ListViewItemSorter = new ListViewColumnSorter();
                list.ColumnClick += new ColumnClickEventHandler(ListView_ColumnClick);
            }
    
            /// <summary>
            /// 构造函数
            /// </summary>
            public ListViewSort()
            {
                //
                // TODO: 在此处添加构造函数逻辑
                //
            }
    
            public static void ListView_ColumnClick(object sender, System.Windows.Forms.ColumnClickEventArgs e)
            {
                System.Windows.Forms.ListView lv = sender as System.Windows.Forms.ListView;
    
                // 检查点击的列是不是现在的排序列.
                if (e.Column == (lv.ListViewItemSorter as ListViewColumnSorter).SortColumn)
                {
                    // 重新设置此列的排序方法.
                    if ((lv.ListViewItemSorter as ListViewColumnSorter).Order == System.Windows.Forms.SortOrder.Ascending)
                    {
                        (lv.ListViewItemSorter as ListViewColumnSorter).Order = System.Windows.Forms.SortOrder.Descending;
                    }
                    else
                    {
                        (lv.ListViewItemSorter as ListViewColumnSorter).Order = System.Windows.Forms.SortOrder.Ascending;
                    }
                }
                else
                {
                    // 设置排序列,默认为正向排序
                    (lv.ListViewItemSorter as ListViewColumnSorter).SortColumn = e.Column;
                    (lv.ListViewItemSorter as ListViewColumnSorter).Order = System.Windows.Forms.SortOrder.Ascending;
                }
                // 用新的排序方法对ListView排序
                ((System.Windows.Forms.ListView)sender).Sort();
            }
        }
    
        /// <summary>
        /// 继承自IComparer
        /// </summary>
        public class ListViewColumnSorter : System.Collections.IComparer
        {
            /// <summary>
            /// 指定按照哪个列排序
            /// </summary>
            private int ColumnToSort;
            /// <summary>
            /// 指定排序的方式
            /// </summary>
            private System.Windows.Forms.SortOrder OrderOfSort;
            /// <summary>
            /// 声明CaseInsensitiveComparer类对象
            /// </summary>
            private System.Collections.CaseInsensitiveComparer ObjectCompare;
    
            /// <summary>
            /// 构造函数
            /// </summary>
            public ListViewColumnSorter()
            {
                // 默认按第一列排序
                ColumnToSort = 0;
    
                // 排序方式为不排序
                OrderOfSort = System.Windows.Forms.SortOrder.None;
    
                // 初始化CaseInsensitiveComparer类对象
                ObjectCompare = new System.Collections.CaseInsensitiveComparer();
            }
    
            /// <summary>
            /// 重写IComparer接口.
            /// </summary>
            /// <param name="x">要比较的第一个对象</param>
            /// <param name="y">要比较的第二个对象</param>
            /// <returns>比较的结果.如果相等返回0,如果x大于y返回1,如果x小于y返回-1</returns>
            public int Compare(object x, object y)
            {
                int compareResult;
                System.Windows.Forms.ListViewItem listviewX, listviewY;
    
                // 将比较对象转换为ListViewItem对象
                listviewX = (System.Windows.Forms.ListViewItem)x;
                listviewY = (System.Windows.Forms.ListViewItem)y;
    
                string xText = listviewX.SubItems.Count > ColumnToSort ? listviewX.SubItems[ColumnToSort].Text : "";
                string yText = listviewY.SubItems.Count > ColumnToSort ? listviewY.SubItems[ColumnToSort].Text : "";
    
                // 移除%号
                while (xText.EndsWith("%")) xText = xText.Substring(0, xText.Length - 1);
                while (yText.EndsWith("%")) yText = yText.Substring(0, yText.Length - 1);
    
                int xInt, yInt;
                float xFloat, yFloat;
    
                // 比较,如果值为IP地址,则根据IP地址的规则排序。
                if (IsIP(xText) && IsIP(yText))
                {
                    compareResult = CompareIp(xText, yText);
                }
                else if (int.TryParse(xText, out xInt) && int.TryParse(yText, out yInt)) //是否全为数字
                {
                    //比较数字
                    compareResult = CompareInt(xInt, yInt);
                }
                else if (float.TryParse(xText, out xFloat) && float.TryParse(yText, out yFloat)) //是否全为数字
                {
                    //比较数字
                    compareResult = CompareFloat(xFloat, yFloat);
                }
                else
                {
                    //比较对象
                    compareResult = ObjectCompare.Compare(xText, yText);
                }
    
                // 根据上面的比较结果返回正确的比较结果
                if (OrderOfSort == System.Windows.Forms.SortOrder.Ascending)
                {
                    // 因为是正序排序,所以直接返回结果
                    return compareResult;
                }
                else if (OrderOfSort == System.Windows.Forms.SortOrder.Descending)
                {
                    // 如果是反序排序,所以要取负值再返回
                    return (-compareResult);
                }
                else
                {
                    // 如果相等返回0
                    return 0;
                }
            }
    
            /// <summary>
            /// 判断是否为正确的IP地址,IP范围(0.0.0.0~255.255.255)
            /// </summary>
            /// <param name="ip">需验证的IP地址</param>
            /// <returns></returns>
            public bool IsIP(String ip)
            {
                return System.Text.RegularExpressions.Regex.Match(ip, @"^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$").Success;
            }
    
            /// <summary>
            /// 比较两个数字的大小
            /// </summary>
            /// <param name="ipx">要比较的第一个对象</param>
            /// <param name="ipy">要比较的第二个对象</param>
            /// <returns>比较的结果.如果相等返回0,如果x大于y返回1,如果x小于y返回-1</returns>
            private int CompareInt(int x, int y)
            {
                if (x > y)
                {
                    return 1;
                }
                else if (x < y)
                {
                    return -1;
                }
                else
                {
                    return 0;
                }
            }
    
            /// <summary>
            /// 比较两个数字的大小
            /// </summary>
            /// <param name="ipx">要比较的第一个对象</param>
            /// <param name="ipy">要比较的第二个对象</param>
            /// <returns>比较的结果.如果相等返回0,如果x大于y返回1,如果x小于y返回-1</returns>
            private int CompareFloat(float x, float y)
            {
                if (x > y)
                {
                    return 1;
                }
                else if (x < y)
                {
                    return -1;
                }
                else
                {
                    return 0;
                }
            }
    
            /// <summary>
            /// 比较两个IP地址的大小
            /// </summary>
            /// <param name="ipx">要比较的第一个对象</param>
            /// <param name="ipy">要比较的第二个对象</param>
            /// <returns>比较的结果.如果相等返回0,如果x大于y返回1,如果x小于y返回-1</returns>
            private int CompareIp(string ipx, string ipy)
            {
                string[] ipxs = ipx.Split('.');
                string[] ipys = ipy.Split('.');
    
                for (int i = 0; i < 4; i++)
                {
                    if (Convert.ToInt32(ipxs[i]) > Convert.ToInt32(ipys[i]))
                    {
                        return 1;
                    }
                    else if (Convert.ToInt32(ipxs[i]) < Convert.ToInt32(ipys[i]))
                    {
                        return -1;
                    }
                    else
                    {
                        continue;
                    }
                }
                return 0;
            }
    
            /// <summary>
            /// 获取或设置按照哪一列排序.
            /// </summary>
            public int SortColumn
            {
                set
                {
                    ColumnToSort = value;
                }
                get
                {
                    return ColumnToSort;
                }
            }
    
            /// <summary>
            /// 获取或设置排序方式.
            /// </summary>
            public System.Windows.Forms.SortOrder Order
            {
                set
                {
                    OrderOfSort = value;
                }
                get
                {
                    return OrderOfSort;
                }
            }
        }
    }
    

    展开全文
  • Excel小技巧-你是否只知道表格按列排序?其实也可以行排序!excel数据行排序。系统默认情况下,数据都是列进行排序的,可以通过简单的操作,让其进行行进行排序。 【解决方法,教程视频资料如下】 本教程视频...

    Excel小技巧-你是否只知道表格按列排序?其实也可以按行排序!excel数据按行排序。
    系统默认情况下,数据都是按列进行排序的,可以通过简单的操作,让其进行按行进行排序。
    Excel小技巧-你是否只知道表格按列排序?其实也可以按行排序!excel数据按行排序

    【解决方法,教程视频资料如下】

    本教程视频资料来源:http://edu.51cto.com/course/15404.html

    完整博客资料:https://blog.51cto.com/13172026/2292179

    完整视频资料:http://edu.51cto.com/lecturer/13162026.html

    转载于:https://blog.51cto.com/13172026/2301422

    展开全文
  • c# DataTable按列排序问题

    千次阅读 2013-06-26 13:41:12
    DataTable按列排序 语句 dtjkchrdata.DefaultView.Sort = "XX asc";  dtjkchrdata = dtjkchrdata.DefaultView.ToTable(); 这个语句是字符或者数字排序,如果事件排序的话datatable的那个被排序的列必须...

    DataTable按列排序

    语句   dtjkchrdata.DefaultView.Sort = "XX asc";
                dtjkchrdata = dtjkchrdata.DefaultView.ToTable();
    这个语句是按字符或者按数字排序,如果按事件排序的话datatable的那个被排序的列必须指定是时间类型,否则排序不正确;比如

       dtjkchrdata.Columns.Add("XX",typeof(DateTime));

    展开全文
  • 【Python】DataFrame行OR按列排序

    万次阅读 2018-11-25 21:32:27
    在进行数据分析操作时,经常需要对数据按照某行某列排序,或者按照多行多列排序,以及按照索引值排序等等,本文将对DataFrame排序作个总结。 1.创建DataFrame数组 这里直接使用numpy的random方法产生随机数组 2...

    摘要

    在进行数据分析操作时,经常需要对数据按照某行某列排序,或者按照多行多列排序,以及按照索引值排序等等,本文将对DataFrame排序作个总结。
    1.创建DataFrame数组
    这里直接使用numpy的random方法产生随机数组
    在这里插入图片描述

    2.按照索引名排序。注意sort_index()方法的axis参数默认为0。
    首先按照索引index排序:排序后索引结果顺序为a、b、c、d。
    在这里插入图片描述

    然后按照列名排序,直接设置参数axis=1即可。
    如下图,即按照列名的首字母排序好了。
    在这里插入图片描述

    3.按照值排序。
    这里注意三参数,axis表示按照行或者列,asceding表示升序OR降序,by表示排序的列名。
    (i)按照one列的值升序(默认)排序
    在这里插入图片描述

    (ii)按照a行降序排序
    在这里插入图片描述

    按照d和a两行降序排序
    在这里插入图片描述

    (iii)对DataFrame列排序同样可以sort_values()方法的by参数和ascending参数。
    eg:同时对one列和four列降序排序:(首先按照one列降序,one列相同的再看four列,参考上面的多行排序)
    在这里插入图片描述

    我们下次再见,如果还有下次的话!!!
    欢迎关注微信公众号:516数据工作室
    516数据工作室

    展开全文
  • CListCtrl实现按列排序

    千次阅读 2012-08-20 20:47:39
    在做的一个项目要求对CListCtrl控件能够实现点击列标题时,实现按列排序。因本来就对MFC不熟悉,故不知从何下手。在网上搜了一些文章,好多都是通过回调函数来实现,找了一篇文章...
  • //矩阵转置 按列排序 /* ================================================================== 题目:输入m*n矩阵,行升序排列输出。 输入: 4 3 5 6 2 9 8 1 2 8 7 1 2 3 8 输出: 2 3 4 5 6 1 2 ...
  • python numpy在保持行的整体性的情况下按列排序
  • 因为python的numpy库可以行进行乱序所以我们的思路是,先把二维list转置,然后在行乱序,最后再转置,这样就得到我们的结果。 import numpy as np labels=[[9,1,3,5], [4,5,6,8], [3,4,5,7], [9,3,2,6]] ...
  • python的按列排序

    千次阅读 2019-01-21 21:36:00
    2019独角兽企业重金招聘Python工程师标准>>> ...key: 使用lambda指定想要排序的key. reverse: 选择升序降序, 默认False为升序   转载于:https://my.oschina.net/nemesis/blog/3004237
  • ant design vue 按列排序 前端实现

    千次阅读 2019-10-16 15:56:03
    表格对某一数据进行排序,通过指定的sorter函数即可启动排序按钮; sorter: function(rowA,rowB){}, rowA/rowB是比较的两个行数据 字符串的比较使用String.prototype.localCompare()方法进行排序。 columns:...
  • Datatable的按列排序排序

    千次阅读 2010-06-24 10:29:00
    Datatable,排序
  • QTableWidget点击表头按列排序

    千次阅读 2019-04-16 09:37:21
    1、连接信号与槽: connect(tableWidget->horizontalHeader(), SIGNAL(sectionClicked(int)), ...2、编写自己的排序槽函数:slot_sortByColumn(int idx)。 可调用QTableWidget的 sortByColumn(int colum...
  • 问题概述   用户能够根据某的内容对表格数据进行排序
  • pandas把csv文件数据按列排序

    千次阅读 2020-03-14 16:18:09
    原本的数据类型凌乱不按照日期排序,不利于数据分析 import pandas as pd df = pd.read_csv('clientinfo-截止2019-1...
  • EXCEL中使用VB按列排序

    千次阅读 2016-10-31 16:38:37
    1 选中需要排序的数据区域 Range("A1:A10")....2 A升序排,有标题行 Selection.Sort Key1:=Range("A1"), Order1:=xlAscending, Header:=xlGuess, _ OrderCustom:=1, MatchCase:=False, Orientation:=xlTopT
  • Matlab 按列排序 去掉重复元素

    千次阅读 2014-04-03 14:19:13
    1. Matlab中,矩阵按照某一列排序    参考:http://kb.iu.edu/data/afrd.html    函数:sortrows(A,j)  例:A = [1 2 3  3 0 9  6 5 4]  B = sortrows(A,2)  则:   B =
  • 对二维数组进行按列排序

    千次阅读 2017-10-24 17:10:57
    //对按列排序后的二维数组行升序排序 (调用快速排序函数)        int   i;   for (i=0;i;i++)   {   qsort (a[i],N, sizeof (a[i][0]),cmp);   }      ...
  • CListCtrl按列排序

    千次阅读 2007-06-06 12:42:00
    CListCtrl 的排序问题目录:问题描述:... 1解决方案:... 2Failed solution:2Successful Solution. 31. CompareFunc两个比较参数的设置... 32.CompareFunc 回调函数的实现... 43. 调用SortItems54.Header头三角的...
  •   查看QT文档的QHeaderView类,发现其中有pressed和clicked信号,然后在QTableWidget的父类QTableView中可以看到sortByColumn()这个API,是按照某一进行排序的,于是可以自定义一个槽函数sortSlot()...
  • Excel中如何按照指定的列排序 一个Excel排序的绿色工具,Excel指定的列(支持多列)的顺序,进行行内容排序。 如果有合并单元格,会自动拆分合并单元格,并给拆分格复值 工具地址:http://www.excelfb.com/, ...
  • 利用 sortrows 函数实现MATLAB 先第一列排序(主排序)然后再第二列排序(次排序) A = [8,9,6;5,5,2;2,5,8] sortrows(A) A = 8 9 6 5 5 2 2 5 8 ans = 2 5 8 5 5 2 ...
  • Java 二维数组指定列排序(二) 上一篇文章【Java 二维数组指定列排序(一)】,我们介绍了二维数组按列排序的方法。本章我们对上次的方法进行修改,使其能够支持不同的排序方式(升序 or 降序)。 效果图: ...
  • js对表格按列进行排序

    千次阅读 2018-03-23 16:31:22
    js表格按列排序 1、列的th设置一个属性,例如: &lt;table&gt; &lt;tr&gt; &lt;th sort='vppv'&gt;&lt;span &gt;VPPV&lt;/span&gt;&lt;/th&gt; &lt;th ...
  • C# DataTable 数字列排序

    千次阅读 2013-12-12 17:14:56
    C# DataTable 数字列排序  C #中DataTable的select方法排序很容易,在这里就不做简述了,下面主要说的是怎么按照数字列排序  下面的例子中讲解这么按照dt2中的第三列按照数字排序:  //这里是从程序 里面弄...
  • JTable列排序

    千次阅读 2016-12-21 22:00:25
    JTable列排序
  • VB.NET excel 列排序

    千次阅读 2014-12-01 11:23:49
    VB.NET excel 按列排序 今天在VB.NET的项目中需要导出数据到EXCEL,并且还要对VB.NET EXCEL进行列的排序操作(sort),总结了下,把关键代码帖出来,备用下 Dim Xls As Excel.Application = New Excel....
  • Java 二维数组指定列排序(一)

    千次阅读 2019-12-06 18:01:16
    Java 二维数组指定列排序 简介: 在做项目时,需要对一个二维数组,按照指定的列进行排序。 效果图: 代码实现: public static void main(String[] args) { int[][] nums = initialArray(5, 3); System.out....
  • python 指定列排序

    万次阅读 2018-12-25 16:39:51
    list01=[[‘1’, 508], [‘1’, 281], [‘7’, 429], [‘9’, 696], [‘9’, 576], [‘g’, 79], [‘f’, 314]] out_data = sorted(list01, key = lambda x:x[1])
  • numpy数组列排序

    千次阅读 2020-08-14 17:29:30
    返回排序索引 a=a[np.argsort(a,axis=0)[:,2],] example: a=np.array([[3,4,3],[2,1,7],[2,3,4],[5,6,2]]) a array([[3, 4, 3], [2, 1, 7], [2, 3, 4], [5, 6, 2]]) a=a[np.argsort(a,axis=0)[:,2],] a ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 630,525
精华内容 252,210
关键字:

怎么按列排序